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(57) Abstract 

Hie invention provides for a data shifting capability that permits sorting the data in addition to searching for obtaining real-time 
performance in color, with high quality imagery through a simple search of a spatial database based on a rectangularly shaped search 
region or range search (fig. 13). A sorting Magnitude Comparison Content Addressable Memory (SMCCAM) performs a range search 
introducing a conservative approximation of the ideal Occluding Region, and provides a MCCAM wherein the data words stored in the 
fields is shifted to corresponding fields in an adjacent word, based on the magnitude comparisons (fig. 7). The 3D graphics method stores 
the parameters of a polygon span in a spatial database (804-814) and a query operation is performed on the database to determine which 
of those spans, or portions of spans, are visible (816 and 818), and applies a rule for comparing new span portion to an old span portion 
on a subspan-by-subspan basis, thereby providing additional polygon edge information within a raster line, providing anti-aliasing. 
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Method and Apparatus for 
Span and Subspan Sorting Rendering System 

Field of the Invention 

5 The field of this invention is twofold: 1) three-dimensional computer graphics; and 2) computer memories, and more 

specifically, Content Addressable Memories (CAM). 

Background of the Invention 

Three-dimensional Computer Graphics 
10 Computer graphics is the art and science of generating pictures with a computer. Generation of pictures, or images, is 

commonly called rendering. Generally, in three-dimensional (3D) computer graphics, geometry that represents surfaces (or vol- 
umes) of objects in a scene is translated into pixels stored in a frame buffer, and then displayed on a display device. Real-time 
display devices, such as CRTs used as computer monitors, refresh the display by continuously displaying the image over and 
over. This refresh usually occurs row-by-row. where each row is called a raster line or scan line. In this document, raster lines are 
15 numbered from bottom to top, but are displayed in order from top to bottom. 

In a 3D animation, a sequence of images is displayed, giving the illusion of motion in three-dimensional space. Inter- 
active 3D computer graphics allows a user to change his viewpoint or change the geometry in real-time, thereby requiring the 
rendering system to create new images on-the-fly in real-time. 

In 3D computer graphics, each renderable object generally has its own local object coordinate system, and therefore 
20 needs to be translated 202 (or transformed) from object coordinates to pixel display coordinates. Conceptually, this is a 4-step 
process: 1) translation (including scaling for size enlargement or shrink) from object coordinates to world coordinates, which is 
the coordinate system for the entire scene; 2) translation from world coordinates to eye coordinates, based on the viewing point 
of the scene; 3) translation from eye coordinates to perspective translated eye coordinates, where perspective scaling (farther 
objects appear smaller) has been performed; and 4) translation from perspective translated eye coordinates to pixel coordinates, 
/ 25 also called screen coordinates. Screen coordinates are points in three-dimensional space, and can be in either screen-precision 
(i.e., pixels) or object-precision (high precision numbers, usually floating-point), as described later. These translation steps can 
be compressed into one or two steps by precomputing appropriate translation matrices before any translation occurs. Once the 
geometry is in screen coordinates, it is broken into a set of pixel color values (that is "rasterized") that are stored into the frame 
buffer. Many techniques are used for generating pixel color values, including Gouraud shading, Phong shading, and texture map- 
, 30 ping. 

A summary of the prior art rendering process can be found in: fundamentals of Three-dimensional Computer Graph- 
ics**, by Watt, Chapter 5: The Rendering Process, pages 97 to 1 13. published by Addison-Wesley Publishing Company, Reading, 
Massachusetts. 1989, reprinted 1991, ISBN 0-201-15442-0 (hereinafter referred to as the Watt Reference). 
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Figure 1 shows a three-dimensional object, a tetrahedron 110. with its own coordinate axes (x^, >obj. *obj)- The three- 
dimenaonal object 110 is translated, scaled, and placed in the viewing point's 130 coordinate system based on (x^y* y^ z^). 
Hie object 120 is projected onto the viewing plane 102, thereby correcting for perspective. At this point, the object appears to 
have become two-diinensional; however, the object*! r-coordinates are preserved so they can be used later by hidden surface 
removal techniques. The object is finally translated to screen coordinates, based on (c,^. ymm , 2tena ) t where z,^ is going 
perpendicularly into the page. Points on the object now have their x and y coordinates described by pixel location (and fractions 
thereof) within the display screen 104 arri their 2 coordinates in a scaled version of distance from the viewing point 130. 

Because many different portions of geometry can affect the same pixel the geometry representing the surfaces closest 
to the scene viewing point 130 must be determined. Thus, for each pixel the visible surfaces within the volume subtended by the 
pixel's area determine the pixel color value, while hidden surfaces are prevented from affecting the pixel Non-opaque surfaces 
closer to the viewing point than the closest opaque surface (or surfaces, if an edge of geometry crosses the pixel area) affect the 
pixel color value, while all other nonopaque surfaces are discarded In this document, the term "occluded" is used to describe 
geometry which is hidden by other non-opaque geometry. 

Many techniques have been developed to perform visible surface deterrnination. and a survey of these techniques are 
incorporated herein by reference to: "Computer Graphics: Principles and Practice", by Foley, van Dam, Feiner. and Hughes, 
Chapter 15: Visible-Surface Determination, pages 649 to 720. 2nd edition published by Addison-Wesley Publishing Company. 
Reading. Massachusetts. 1990, reprinted with corrections 1991. ISBN 0-201-121 10-7 (hereinafter referred to as the Foley Refer- 
ence). In the Foley Reference, on page 650, the terms "image-precision" and "object-precision" are defined: "Image-precision 
algorithms are typically performed at the resolution of the display device, and determine the visibility at each pixel. Object-pre- 
cision algorithms are performed at the precision with which each object is defined, and determine the visibility of each object." 

As a rendering process proceeds, most prior art renderers must compute the color value of a given screen pixel multi- 
ple times because multiple surfaces intersect the volume subtended by the pixel. The average number of times a pixel needs to be 
rendered, for a particular scene, is called the depth complexity of the scene. Simple scenes have a depth complexity near unity, 
while complex scenes can have a depth complexity of ten or twenty. As scene models become more and more complicated, ren- 
derers will be required to process scenes of ever increasing depth complexity. Thus, for most renders, the depth complexity of a 
scene is a measure of the wasted processing. For example, for a scene with a depth complexity often, 90% of the computation is 
wasted on hidden pixels. This wasted computation is typical of hardware renderers that use the simple Z-buffer technique (dis- 
cussed later herein), generally chosen because it is easily built in hardware. Methods more complicated than the Z-buffer tech- 
nique have heretofore generally been too complex to build in a cost-eMective manner. An important feature of the method and 
apparatus invention presented here is the avoidance of this wasted computation by eliminating hidden portions of geometry 
before they are rasterized, while still being simple enough to build in cost-effective hardware. 

When a point on a surface (frequently a polygon vertex) is translated to screen coordinates, the point has three coordi- 
nates: 1) the x-coordinate in pixel units (generally including a fraction); 2) the y<oordinate in pixel units (generally including a 
fraction); and 3) the r-coordinate of the point in either eye coordinates, distance from the virtual screen, or some other coordinate 
system which preserves the relative distance of surfaces from the viewing point In this document, positive 2-coordinate values 
are used for the "look direction" from the viewing point, and smaller values indicate a position closer to the viewing poinL 

When a surface is approximated by a set of planar polygons, the vertices of each polygon are translated to screen coor- 
dinates. For points in or on the polygon (other than the vertices), the screen coordinates are interpolated from the coordinates of 
vertices, typically by the processes of edge walking 218 and span interpolation 220. Thus, a inordinate value is generally 
included in each pixel value (along with the color value) as geometry is rendered. 
Generic 3D Graphics Pipeline 

Many hardware renderers have been developed, and an example is incorporated herein by reference: "Leo: A System 
for Cost Effective 3D Shaded Graphics", by Deering and Nelson, pages 101 to 108 of SIGGRAPH 93 Proceedings, 1-6 August 
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1993. Computer Graphics Proceedings, Annual Conference Series, published by ACM SIGGRAPH. New York, 1993. Softcover 
ISBN 0-20L58889.7 and CD-ROM ISBN 0-201-56997-3 (hereinafter referred to as the Deering Reference). The Deexing Refer- 
ence includes a diagram of a generic 3D graphics pipeline 200 (Le- arendercr, or a rendering system) that it describes as "truly 
generic, as at the top level nearly every commercial 3D graphics accclmtor fits this abstraction", and this pipeline diagram is 
reproduced here as Figure 2. Such pipeline diagrams convey the process of rendering, but do not describe any particular hard, 
ware. This document presents a new graphics pipeline 400 that shares some of the steps of the generic 3D graphics pipeline 200. 
Eadi of me steps m the generic 3D graphic 

diagram 300 of Figure 3. Processing of polygons is assumed throughout this document, but other methods for describing 3D 
geometry could be substituted. For simplicity of explanation, triangles are used as the type of polygon in the described methods. 

As seen in Figure 2, the fist step within the floating-point intensive functions 250 of the generic 3D graphics 
pipeline 200 is the transformation step 202, which was described above. The transformation step 202 is also shown in Figure 3 
as the first step in the outer loop of the method flow diagram 300. and also includes "get next polygon-. The second step, the clip 
test 204, checks the polygon to see if it is at least partially contained in the view volume 106 (sometimes shaped as a frustum). If 
tbe polygon is not in the view volume 106. it is discarded; otherwise processing continues. The third step is face 
determination 206, where polygons facing away from the viewing point are discarded. Generally, face determination 206 is 
applied only to objects that are closed volumes. The fourth step, lighting computation 208, generally includes the set up for 
Gouraud shading and/or texture mapping with multiple light sources of various types, but could also be set up for Phong shading 
or one of many other choices. The fifth step, clipping 210, deletes any portion of the polygon that is outside of the view 
volume 106 because that portion would not project within the rectangular area of the viewing plane 102. Generally, polygon 
cupping 210 is done by splitting the polygon into two smaller polygons that both project within the area of the viewing 
plane 102. Polygon clipping is computationally expensive, but its need is avoided in the invention presented here, thus providing 
computational savings. The sixth step, perspective divide 212. does perspective correction for the projection of objects onto the 
viewing plane 102. At this point, the points representing vertices of polygons are converted to pixel-space coordinates by step 
seven, the screen space conversion 214 step. The eighth step, set up for incremental render 216, computes the various begin, end, 
and increment values needed for edge walking 218 and span interpolation 220 (eg.: x, y, and coordinates; RGB color, texture 
map space u and v-coordinaies; etc.). 

Within the drawing intensive functions 260, edge walking 218 wcrementalry generates horizontal spans for each raster 
line of the display device by incrementing values from the previously generated span (in the tame polygon), thereby "walking" 
vertically along opposite edges of the polygon. Similarly, span mterpolation220 "walks" horizontally along a span to generate 
pixel values, including a incoordinate value indicating the pixel's distance from the viewing point 130. By comparing this 
z -coordinate value to the corresponding value stored in theZ-buffer, the z-buffered blend222 either keeps the new pixel values 
(if it is closer to the viewing point than previously stored value for that pixel location) by writing it into the frame buffer224, or 
discards the new pixel values (if it is farther). At this step, antialiasing methods (discussed in the next section) can blend the new 
pixel color with the old pixel color. 

The generic 3D graphics pipeline 200 includes a double buffered frame buffer 224, so a double buffered MUX 226 is 
also included. An output lookup table 226 is included for translating color map values. Finally, digital to analog conversion 228 
makes an analog signal for input to the display device. 

A major drawback to the generic 3D graphics pipeline 200 is its drawing intensive functions 260 are not deterministic 
at the pixel level given a fixed number of polygons. That is, given a fixed number of polygons, more pixel-level computation is 
required as the average polygon size increases. However, the floating-point intensive functions 250 are proportional to the num- 
ber of polygons, and independent of the average polygon size. Therefore, it is difficult to balance the amount of computational 
power between the floating-point intensive functions 250 and the drawing intensive functions 260 because this balance depends 
on the average polygon size. 
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An ideal ienderer's pixel drawing computational requirement would be proportional to the number of pixels in the dis- 
play screen 104, rjot the total number of pixels mall tte 

described here because bidden geometry is removed before most drawing intensive amotions are performed. In the invention 
described here, computational load balancing is not a problem because the anv>um of floating-point computation is essentially 
independent of the amount of drawing computation. 
Antialiasing 

In this document, pixels are defined to be the smallest mdmduaDy controllable element of the display device. But, 
because images are quantized into ipaiiil aliasing occurs, A typical aliasing artifact is a "staircase" effect caused 

when a straight line or edge cuts diagonally across rows of pixels. An ideal image eliminates this "staircase" effect by 

calculating, for each pixel, an average color by taking into account partial coverage by the visible surfaces within the pixel's 
area. 

Some rendering systems reduce aliasing effects by dividing pixels into subpixela, where each sub-pixel can be colored 
independently. When the image is to be displayed the colors for all sub-pixels within each pixel are blended together to form an 
average color for the pixel A Tenderer that uses 16 sub-pixels per pixel is described in "RcalityEngine Graphics", by Akeley, 
pages 109 to 1 16 of SIGGRAPH 93 Proceedings, 1 -6 August 1993, Computer Graphics Proceedings, Annual Conference Series, 
published by ACM SIGGRAPH, New York. 1993, Softcover ISBN 0-201-58889-7 and CD-ROM ISBN 0-201-56997-3 (herein- 
after referred to as the Akeley Reference). The drawback with using subpixels is the increase in computation due to computing 
color values at every subpixel. In the Akeley Reference, the increase in computation it reduced by only dividing a pixel into sub- 
pixels when the pixel is crossed by a line or an edge of a polygon. This reduction becomes less significant as the number of poly- 
gons increases. In other words, if the image is made up of lots of small overlapping polygons, then most pixels will need to be 
divided. Utilization of subpixels is an irnage-precision antialiasing technique. 

Another prior art antialiasing method is the A-Buffer used to perform alpha blending (this technique is also included in 
the Akeley Reference), and is described in The A-buffer, an Antialiased Hidden Surface Method** by L. Carpenter. SIGGRAPH 
1984 Conference Proceedings, pp. 103-108 (heieinafter referred to as the Carpenter Reference). The A-buffer is an image-preci- 
sion antialiasing technique that reduces aliasing by keeping track of the percent coverage of a pixel by a rendered polygon. The 
main drawback to this technique is the need to sort polygons front-to-back (or back-to-front) at each pixel in order to get accept- 
able antialiased polygons. 

An ideal antialiasing method would perform object-precision computations to precisely identify the visible portions of 
geometry. This would require comparing edges of polygons to each other in order to determine the fraction of each pixel covered 
by each polygon. The invention of this document performs object-precision antialiasing within each scan line, thus achieving this 
ideal. 
Z-bufTers 

Stated simply, the Z-buffer stores, for every pixel tbez-cooromate of the closest geometry (to the viewing point) that 
affects the pixel Hence, as new pixel values are generated, each new pixd*s;<oordinate is compared to the corresponding loca- 
tion in the Z-buffer. If the new pixel's i-coordinate is smaller (Le M closer to the viewing point), this value is stored into the 
Z-buffer and the new pixel's color value is written into the frame buffer. If the new pixel , s2^oordinate is larger (Le^ farther from 
the viewing point), the frame buffer and Z-buffer values are unchanged and the new pixel is dtmrdfd. The Z-buffer is an image- 
precision visible surface deterrninarion technique. 

A flow diagram including the prior art Z-buffer method is shown in Figure 3. The main drawback to the Z-buffer hid- 
den surface removal method is the requirement for geometry to be converted to pixel values before bidden surface removal can 
be done. This is because the keep/discard decision is made on a pixel-by-pixel basis. In contrast, the invention of this document 
performs hidden surface removal at a higher level by processing spans rather than pixels. For scenes with any significant depth 
complexity, pixel-by-pixel bidden surface removal mrxoduces much wasted computation by requiring all geometry within the 
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view volunw to be converted to pixels 

pixel color generation (shading, texture mapping, etc) often hippens in parallel with the Z-buffer comparison text, thereby com- 
pounding the wasted computation because much of the computation is asaonstrd with color generation, and most of the pixels 
are thrown away. Furthermore, the Z-buffer memory operation is a read-modify-write cycle, generally requiring the Z-buffer 
memory input/output bus to change directions twice when writing pixels into the frame buffer, thereby causing a bottleneck in 
therenderer. This bottleneck does not occur in the apparatus and method of the document's invention. 

Prior art Z-buffers are based on conventional Random Access Memory (RAM), Video RAM (VRAM), or special pur- 
pose DRAMs. One example of a special purpose DRAM is presented in TBRAM: A new Farm of Memory Optimized for 3D 
Graphics-, by Deering, Schlapp, and Lavelle, pages 167 to 174 of SIGGRAPH 94 Proceedings, 24-29 July 1994, Computer 
Graphics Proceedings. Annual Coiiference Series, published by ACM SIGGRAPH, New York, 1994, Softcover ISBN 
0-201-60795-6. 
Geometry Databases 

The geometry needed to generate a renderable scene is stored in a database. This geometry can be a simple 

display list of graphics primitives or a hierarchically organized data structure. In the hierarchically organized geometry database, 
the root of the hierarchy is entire database, and the first layer of subnodes in the data structure is generally all the objects in the 
"world" which can be seen from the viewpoint. Each object, in turn, contains aubobjects. which contain sub-subobjects; thus 
resulting in a hierarchical "tree" of objects. Hereinafter, the term "object" shall refer to any node in the hkrarchial tree of objects. 
Thus, each subobject is an object. The term "root object" shall refer to a node in the first layer of subnodes in the data structure. 
Hence, the hierarchical database for a scene starts with the scene root node, and the first layer of objects are root objects. 

Hierarchical databases of this type are used by the Progiamroer's Hierarchical Iiueractive System (PHIGS) and PHIGS 
PLUS standards An explanation of these standards can be found in the book. "A Practical Introduction to PHIGS and PHIGS 
PLUS", by T. L. J. Howard, et. aL. published by Addison-Wesley Publishing Company, 1991, ISBN 0-20M1641-7 (incorpo- 
rated herein by reference and hereinafter called the Howard Reference). The Howard Reference describes the hierarchical nature 
of 3D models and their data structure on pages 5 through 8. Hierarchical models can provide a separate transformation matrix at 
each layer of the hierarchy, thereby making it possible to move models or parts of a models simply by changing a transformation 
matrix. This allows non-changing model geometry (in object coordinates) to be used as moving objects in an animation. 
Content Addressable Memories 

Most Content Addressable Memories (CAM) perform a bit-for-bit equality test between an input vector and each of 
the data words stored in the CAM. This type of CAM frequently provkies masking of bit positions in order to eliminate the cor- 
responding bit in all words from affecting the equality test It is inefficient to perform magnitude comparisons in a equality-test- 
ing CAM because a large number of clock cycles is required to do the task. 

CAMs are presently used in translation look-aside buffers within a virtual memory systems in some computers. CAMs 
are also used to match addresses in high speed computer networks. CAMs are not used in any practical prior art renders. 

Magnitude Comparison CAM (MCCAM) is defined here as any CAM where the stored data are treated as numbers, 
and arithmetic magnitude comparisons (Le. leas-thin, greater-than, less-than-or-equal-to, etc.) are performed on the data in par- 
allel. This is in contrast to ordinary CAM which treats stored data strictly as bit vectors, not as numbers. An MCCAM patent, 
included herein by reference, is U.S. Patent Number 4.996,666, by Jerome F. Duluk Jr., entitled Content-Addressable Memory 
System Capable of Fully Parallel Magnitude Comparisons", granted February 26, 1991 (hereinafter referred to as the Duluk 
Patent). Structures within the Duluk Patent specifically referenced shall include the prefix "Duluk Patent" (for example, "Duluk 
Patent MCCAM Bit Circuit"). MCCAMs are not used in any prior ait renderer. 

The basic internal structure of an MCCAM is a set of memory bits organized into words, where each word can perform 
one or more arithmetic magnitude comparisons between the stored data and input data. In general, for an MCCAM, when a vec- 
tor of numbers is applied in parallel to an array of words, all arithmetic comparisons in all words occur in parallel. Such a paral- 
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lel search comparison operation is called m •'query** of the stored dais. 

The invention described here a ngn^ various features, induding the ability 

to perform sorting. This new type of MOCAM is call Sorting Magnitude Comparison CAM (S MCCAM). 

Summary of the Invention 

Computer graphics is the art and science of generating pictures or images with a computer. This picture generation is 
commonly referred to as rendering. The appearance of motion, for example in a 3-Dimertsional animation is achieved by dis- 
playing a sequence of images. Interactive 3-Dtmensional (3D) computer graphics allows a user to change his or her viewpoint or 
to change the geometry in real-time, thereby requiring the rendering system to create new images on-the-fly in real-time. There- 
fore, real-time performance in color, with high quality imagery is becoming increasingly important 

The inventive apparatus and method provide a data shifting capability that permits sorting the data in addition to 
searching. It also provides a new way to perform a simple search of a spatial database based on a rectangularly shaped search 
region or range search. The range search may be performed in a special new Sorting Magnitude Comparison Content Address- 
able Memory (SMCCAM) apparatus. This SMCCAM provides a magnitude comparison content addressable memory wherein 
the data stored in the fields in each word of the memory may be shifted to corresponding fields in an adjacent word, where this 
shifting is conditionally performed based on the results of the magnitude comparisons. 

The 3D graphics method stores the parameters of a polygon span in a spatial database, and a query operation is per- 
formed on the database to determine which of those spans, or portions of spans, are visible. The spatial database of spans can be 
stored in an SMCCAM. The SMCCAM apparatus is significant because its operation is fast enough to support real time opera- 
tion, such as for standard and emerging video technologies (NTSQ PAL, HDTV, and the like), visual flight simulators, virtual 
reality image generators* and the like, among other applications. 

Since the range search is used, it introduces a conservative approximation of the ideal Occluding Region. An Occlud- 
ing Test is provided which defines an Occluding Test Region as an approximation to the ideal Occluding Region. A rule based 
method is used when comparing the Current Span Portion with the New Spaa where the New Span is found by the Occluding 
Test and read out of the data structure stored in memory. That memory may advantageously be the SMCCAM, or it may be a 
conventional memory that implements the spatial data structure with conventional spatial database methods. Based on the results 
of the comparison, one rule out of several possible simple rules are selected and applied to determine which piece of the Current 
Span is visible, if any. Several alternative rules are d^wrifrfd. 

Multiple alternative span representations are provided, including a Segment Span, Trapezoidal Span, and Quadrilateral 
Span. Each of these Spans is defined by its own set of span parameters, of which there are multiple selections of each. The span 
parameters are stored in a data structure in memory, which may be implemented by the SMCCAM, and are used during the 
query search operation. Each of these Span types have their own advantages. For example, a Trapezoidal Span or a Quadrilateral 
Span provides superior antialiasing performance than provided by a Segment Span. This performance advantage is achieved by 
preserving the left and right edge information of the polygon within a particular raster line. Several ways to handle the query 
operation for Trapezoidal and Quadrilateral Spans are described. 

Spatial searching and sorting apparatus and methods are provided such that spatial searching and sorting can be used 
to properly render transparent polygon spans in front-to-back or back-to-front order. 

As a possible improvement to the method and apparatus, rather than using two distinct memories (Bucket Sort Mem- 
ory and Current Polygon Memory) to store polygon geometry information once they have translated to screen coordinates, a sin- 
gle memory (Sort Memory) can be used to store the polygon geometry information. This can be done by replacing the Current 
Polygon Memory with a list of pointers into the Sort Memory, thereby eliminating copying Polygon Parameters form Bucket 
Sort Memory to Current Polygon Memory. 

As another possible improvement for trapezoidal spans and quadrilateral spans, the spatial data structure can store the 
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parameterstf the entire span, and when the fl y< wncre 

these subspans tie vertically distributed ever u* beigte 

paring the Current Span Portion to the New Span are applied on a subspan-by-wbspan basis, thereby providing additional poly, 
gon edge information within a raster line, which, in turn, provides antialiasing. Once again, for real-time performance, the spatial 
data structure can be stored in a SMCCAM. 

The inventive apparatus, system, and method also provide several options and enhancements to the basic system. 
These include, by way of example: preservation of rendering order, utilization of a single-buffered frame buffer for increased 
compatibility with conventional video cards, the ability to selectively turn on or off antialiasing on specific polygon edges, the 
ability to store edge-pairs rather than polygons thereby sunplifying downstream rraeasing, the ability to cliininate the Current 
Polygon Memory by replacing it with a list of pointers, the ability to add clipping planes (front, rear, and/or arbitrary), provision 
of a Geometry Cache for storing geometry as it is input for rendering, flexible options for the number of pages of Span Memory 
and Page Memory I/O bus architecture, support for geometry primitives other than polygons (such as CSG primitives), and alter- 
natives that support the inventive method in conventional hardware with some performance compromises. 

A Brief Description of the Drawings 

Figure 1: An object in three-dimensional space, its projection onto the viewing plane, and its image one a display 

screen. 

Figure 2: Generic rendering pipeline from the Deering Reference (prior art). 
Figure 3: Method flow diagram for the standard Z-buffer method (prior art). 

Figure 4: The Span Sorting Rendering Pipeline. The Span Memory can be implemented with a SMCCAM800. 
Figure 5: A block diagram of the Span Sorting Rendering Architecture. 

Figure 6: An example of nine polygons showing how they intersect the display screen and bow they are included in a 
particular raster line. 

Figure 7: Three ways to model a polygon span: 1) a line segment; 2) a trapezoid; and 3) a quadrilateral. 
Figure 8: Data organization within the Sorting Magnitude Comparison Content Addressable Memory 800 
(SMCCAM 800). 

Figure 9: SMCCAM Word 900 block diagram. 

Figure 10: The area covered by a Span Occluding Test query, iiicluding two Potentially Occluding Spans. 
Figure 1 1: An example set of spans on one raster line, shown in** space. 

Figure 12: The same example set of spans as shown in Figure 1 1, except with bounding boxes around each span. 
Figure 13: The Span Sorting Rendering Method 1300 flow diagram. 

Figure 14: The Process Polygon Method 1400 flow diagram, part of the Span Sorting Rendering Method 1300. 
Figure 15: The Process Current Polygon Memory Method 1500 flow diagram, part of the Span Sorting Rendering 
Method 1300. 

Figure 16: The Process Bucket Sort Memory Method 1800 flow diagram, part of the Span Sorting Rendering 
Method 1300. 

Figure 17: The Write Span Parameters Method 1700 flow diagram. 

Figure 18: The Simplified Span Rasterization Method 1800 flow diagram, part of the Span Sorting Rendering 
Method 1300. 

Figure 19: Span interaction nomenclature definitions. 
Figure 20: The 36 varieties of Span Interaction Types. 

Figure 21: Segment Span Ra s te ri zation Method 21 00 flow diagram, part of the Span Sorting Rendering 
Method 1300. 
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Figure 22; Rule 1 2200 method flow diagram, part of Segment Span Rasterization Method 21 00. 
Figure 23: Rule 2 2300 method flow Hi.^m pm of Segment Span Rasterization Method 21 00. 
Figure 24: Rule 3 2400 method flow diagram, part of Segment Span Rasterization Method 21 00. 
Figure 25: Rule 4 2500 method flow diagrun, part of Segment Span Rasterization Method 21 00. 
Figure 26: Rule 5 2600 method flow diagram, part of Segment Span Rasterization Method 21 00. 
Figure 27: An example raster line with fifteen spans. The bounding box of each span is shown as well as each span's 
*L location along the x axis. 

Figure 28: Timing diagram for phase-locked raster line processing and display. 
Figure 29: Timing diagram for single buffered frame buffer. 

Figure 30: Timing diagram for single buffered frame buffer where span rasterization covers more than one screen dis- 
play time. 

Figure 3 1 : Block diagram of the Span Processor hardware architecture. 

Figure 32: Block diagram of the Comparison and Offset Computation block within the Span Processor. 

Figure 33: Prior art MCCAM CMOS bit cell. 

Figure 34: A "TIL type*' circuit for an SMCCAM bit cell. 

Figure 35: A CMOS circuit for the SMCCAM bit cell that uses static storage for the master half of the master-slave 

flip-flop. 

Figure 36: A CMOS circuit for the SMCCAM bit cell that uses dynamic storage for both halves of the master-slave 

flip-flop. 

Figure 37: An array.of SMCCAM bit cells. 

Figure 38: Multiple spans vertically within a raster line. 

Figure 39: Two trapezoidal spans working together to occlude farther spans that would be visible if the shown trape- 
zoidal spans did not work together. 

Figure 40: An example set of trapezoidal spans, shown in jr-z space. 
Figure 41: SOT Query for Processing Top and Bottom Separately 

Figure 42: An example set of trapezoidal spans used to illustrate the Trapezoidal Span Rasterization Method version 
that does occlusion processing on span tops and span bottoms separately. 
Figure 43: SOT Query for processing every visibility transition 
Figure 44: SOT Query with Complex Shape 
Figure 45: SOT Query with Wider Search Area 

Figure 46: A set of segment spans in a raster line where the visible opaque surfaces are shown as thick black lines and 
the visible translucent spans are shown as thick shaded lines. 

Figure 47: Approximating trapezoidal spans using only one i-value per endpoint changes the spans into quadrilateral 

spans. 

Figure 48: An example set of quadrilateral spans, shown inx-z space. 
Figure 49: Span Sorting Rendering Pipeline with Direct Span Generation. 
Figure 50: Span Sorting Renderer Architecture with Direct Span Generation. 
Figure 51: An alternate set of Polygon Parameters as stored in Sort Memory 4904. 
Figure 52: Generic triangle parameters. 

Figure 53: An alternate span representation as stored in the Span Parameter Registers 31 04. 
Figure 54: An alternate span representation as sent to the Rasterize Processor 51 2. 
Figure 55: An alternate set of Span Parameters as stored in Span Memory 408. 
Figure 56: Multiple trapezoidal spans can be generated when a corner is included. 
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Detailed Description of the Invention 

Span Sorting Rendering Pipeline 

Rgure4 ihowf the Span Sorting 3D Graphics Pipeline 400, where the first six steps are denned as the process 
polygon 1400 steps. The first five steps (traiutforrnatioo 201 clip test 204, face (trJrrminsrton 206, lighting 208, and perspective 
divide 212) are the same as the five of the first six steps in the Generic 3D Graphics Pipeline200. Tnc clip 210 step is omitted 
because the Span Sorting 3D Graphics Pipeline 400 operates in object-pnxasion, and coordinates are not limited to the area of 
liie display screen 104. Eliminaoon 

ever, the clip 210 step can be inserted if desired. The Span Sorting 3D Graphics Pipeline 400 can be built with dedicated hard- 
ware, done completely in software, 01 a combination of the two. Hereinafter, a dedicated hardware implementation is assumed, 
and a new apparatus is described. 

The top-level block diagram of the new apparatus is shown in Figure 5. The process polygon 1400 steps are performed 
in the Polygon Processor502. The last step performed by the Polygon Processor 502 is the computation of the Polygon 
Parameters 402. The Polygon Parameters, output by the Polygon Processor502. describe a polygons as needed by the rest of the 
Span Sorting 3D Graphics Pipeline 400. 

Tot each polygon. Polygon Parameters are written into the Bucket Sort Memory 400. and include: 1) the location in 
object-precision screen coordinates of the polygon vertices, V„ V 2 . V 3 , etc. defined respectively as: (x,.y,. 2l ). (xj.y*^). 
<** >3. etc.; 2) color information, including such things as vertex colors for Gouraud (or Phong) shading and/or texture map- 
ping parameters; 3) the edge derivatives of x and x with respect toy (Le. hxfcy and 6x/6y) for each edge; 4) starting raster line (or 
*p™>*\ >stxxt; 5) ending raster line (or bottommost), y^ND* and 6) the span derivative of; with respect to* (Le^cWSv), 
assigned to the variable d. The last four m this list need to be computed 402, and this is done in the Polygon Processor 502. 

Assuming the polygons are triangles, the edge derivatives are computed as: 

Sx 12 g *l~*2 8x 23 _ *2~*3 5 *31 *3~*1 

6 >12 = yi-y 2 . ^"^-^ ^"V 7 ^ 

* * (EO 1) 

52 12_*l-*2 S *23_*2-*3 5Z3J 

^12 yi-y 2 ^"^-^ 5 >3i s >3-yi 

When the starting raster line, >staktv «nd the ending raster line, y^ are computed, the edges of the display 
screen 104 must generally be taken into account Figure 6 shows a display screen 104 with eight polygons (in this case, trian- 
gles), some of which intersect the edges of the display screen 104. If a polygon does not intersect the right or left edges of the 
display screen 104, then ysxvRT *nd y^ are computed by: 

>start = Min °f (y MAX , IntPartOf (MaxOf (y v y y y v ...))) 

>bnd = MaxOf (0, IntPartOf (MinOf (y v y v y v ...))) 2) 

The computation ofy^^ first finds the maximum of they-coordinatcs of the vertices of the polygon, thereby finding 
the "uppermost" y-coordinate in the polygon. Then, the function IntPartOf() takes the -integer part or the uppermost 
y^oordinate, thereby computing the raster line of the *%mpermosr y-cooidinate in the polygon. Since the start of the polygon 
can not be above the topmost raster line in the display screen 104, the MinOf( ) function substitutes yuAX if the polygon would 
start in a non-existent raster line. Computation ofy^ is done similarly. Figure 6 shows a polygon 602 that starts aty^^, and 
another 604 that ends at raster line zero. 

If a porygon intersects the right or left edges of the dispky screen 
last raster lines that is affected by the polygon within the display screen 104. In Figure 6, an example polygon 606 begins at 
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y A 608 and ends atjfc 610. Another example polygon 612 begins at y c 614 and ends at raster line zero. The effects of the right 
and left edges of the display screen 104 can be ignored, but then span generation 1500 wili create spans that ire not within the 
display screen 104, and therefore must test for this, and throw away such spans. 

Computation of the span derivative, d (Le^ 6z/Sx), can be computed in one of many conventional ways. 

d ~ be 

The span derivative is constant for each planar polygon and can have either a positive or a negative value. 

Writing into the Bucket Sort Memory 404 is done according to y^jfj for each polygon. There is one "bucket" per 
raster line, and a polygon is placed into the one bucket mat corresponds to its starting raster line. Within each bucket, polygons 
do not need to be sorted. Management of the data in the Bucket Sort Memory 404 is done by the Bucket Son Processor 504. 
which can do the sort with one linked list per bucket. In addition, the Bucket Sort Memory 404 can be double buffered so the 
write operations associated with a scene can be performed concurrently with read operations from the previous scene. 

If all the color information described above is stored into the Bucket Sort Memory 404. it must be carried along, 
through the Span Sorting Renderer500 (see Figure 5) all the way to the Rasterize Processor512. Alternatively, the color infor- 
mation in the Bucket Sort Memory 404 can be replaced by an information pointer, and then stored into a separate Polygon Infor- 
mation Memory 514. The information pointer is an address into the Polygon Information Memory 514 where all the color 
information for the polygon is stored, and can be used by the Rasterize Procc*sor512 to read the color information. The informa- 
lion pointer is carried along to the Rasterize ProcessorSU. This saves expensive hardware memory throughout the Span Sorting 
Rcnderer 500 because the iiifonnation pointer has very few bits when compared to all the color information for a polygon. This 
savings can be done because: 1 ) the color information is constant over the entire polygon, and so can be shared by all the spans 
of the polygon; and 2) the color information is not needed until visible span portions are colored by the Rasterize ProcessorSU. 
The use of the information pointer and the Polygon Information Memory 514 will be assumed in the rest of this document 

Within the Span Sorting Rcnderer 500. a list is kept in the Current Polygon Memory 406 of all the polygons that affect 
the raster line that is currently being rendered Hence, when the rendering of a scene begins, the Current Polygon Memory 406 is 
empty. During rendering, when a particular raster line is reached, all the polygons that have theirysx^j at that raster line (Le.. 
that particular bucket) are read from the Bucket Sort Memory 404 and added to the Current Polygon Memory 406. As rendering 
proceeds, polygons are deleted from the Current Polygon Memory 406 as their values are reached. The data in the Current 
Polygon Memory 406 is managed by the Current Polygon Processor 506, which performs the operation "process data from 
Bucket Sort Memory 404" 1600. as shown in the pipeline diagram 400. Also, the Current Polygon Processor 506 feeds the poly- 
gons that affect the raster line to the Span Generation Processor508. 

Starting at the beginning of the rendering of a raster line, each polygon that has a span in that raster line is input to the 
Span Generation Processor 508. which performs span generation 1600. The Span Generation Processor 508 uses the geometric 
properties of each polygon, including its edge derivatives of Equation 1, to compute the location in object-precision screen coor- 
dinates of the left and right endpoints of its span within the current raster line. The span can be modeled as a simple line segment, 
a trapezoid, or a quadrilateral as shown in figure 7. The geometric properties of the span are sent to the Query ProcessorSlO, 
and those properties include: 1) coordinates of the left endpoint of the span; 2) coordinates of the right endpoint of the span; 
3) the span derivative, d\ and 4) the information pointer. The coordinates of a span endpoint can be: 1 ) an (c, z) point within the 
current raster line, used when spans are modeled as line segments as in Figure 7 A; 2) two r) points, one for the top edge of the 
current raster line and one for the tower edge, used when spans are modeled as trapezoids as in Figure 7B; or 3) an fry, x L , z) 
triplet including one r-coordinate and an x-coordinate for tbe upper and lower edges of the current raster line, used when spans 
are modeled as quadrilaterals as in Figure 7C Of the eight example polygons shown in Figure 6, four of them616 9 618, 620, 622 
have spans 626, 628, 630, 632 on the example current raster line 640. Note that one of the example spans 626 starts at a negative 
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jr-vahie. 

For a given raster line, as geometric properties of spin* are output from tbe Spaa Generation Procesjor508, they are 
received by the Query Processor 510 that then writes them all into one bank of tbe doable buffered Span Memory 406. As the 
spans are written into the Span Memory 406, they are sorted, in order of precedence, by: 1) the kttx-a»rdinate; 2) the left 
2-coordinate; and 3) the span derivative. Simultaneous to writing span daia into one bank, the span data in the other bank of Span 
Memory 406 is processed to discover visible span portions. 

When the Query Processor 510 has completed processing the spans stored in one bank of the Span Memory 406, and 
all the spans in the next raster line have been received from the Span Generation Processor508 and written into the other bank, 
the two banks of the Span Memory 406 are swapped. After the bank swap, the Query Prcce*sor510 and the Span Memory 406 
jointly perform arithmetic comparisons on the span data (hereinafter called query operations) and various arithmetic operations 
to process 1800 or 2100 the spans and determine which spans or portions of spans are visible in the scene. These visible spans 
(or portions of spans) are sent to the Rasterize Processor 512. A more detailed block diagram of the Query Processor 510 and the 
Span Memory 406 is shown as Figure 31 . 

The Rasterize Processor 512 receives only spans (or portions of spans) that are fully visible. To process each span, the 
Rasterize Processor 512 performs the set up for incremental span render 412 and then performs span interpolation 220. Pixel 
color values arc generated by utilizing the data stored in the Polygon Information Memory514 and possibly also the Texture 
Map Memory 516. As pixel color values are generated, they arc written into the Raster Line Memory416. 

The Raster Line Memory 416 can store all the color pixel values for several complete raster lines. That is, it416 stores 
the color values for the raster line currently being fed to the digital to analog converter 228 (via the Rasterize Processor 512) as 
well as several subsequent raster lines. Once all the values for a particular raster line nave been sent to the digital to analog 
converter 228, the corresponding part of the Raster Line Memory 416 can be overwritten with another raster line. In this way. the 
total amount of memory required is only a few raster lines worth (the minimum is two), rather than the typical doubled buffered 
full display screen 104 frame buffer 224 required by prior art 3D graphics renders. This saves many megabytes of memory. The 
Raster Line Memory 416 can store data for several raster lines in order for the rasterization process to "work ahead" of the digi- 
tal to analog converter 228, thereby providing some time cushion for raster lines that require more than the average amount of 
time to process. 

Having only enough memory for a few raster lines requires the Span Sorting Renderer500 architecture to keep up with 
the average raster line display rate. Therefore, if very large geometry databases (larger than the maximum where the Span Sort- 
ing Renderer 500 can keep up) need to be rendered, the Raster Line Memory 416 can be replaced with a doubled buffered full 
display screen 104 frame buffer 224. 

Sorting Magnitude Comparison Content Addressable Memory 800 

A diagram of data storage 800 within a page of Span Memory 406 is shown in Figure 8. This data array can reside in 
typical random access memory (RAM) as a sorted data structure, or reside in Sorting Magnitude Comparison Content Address- 
able Memory (SMCCAM). The SMCCAM implementation will be assumed in the rest of this document 

An SMCCAM is a new type of MCCAM. and is comprised of a set of memory registers (or wordsX each word com- 
posed of a multiplicity of fields, where each field can: 1) store a number, either as an integer or as a floating-point number, 
2) perform arithmetic comparisons between the stored number and another number broadcast to all words; and 3) shift its con- 
tents to the corresponding field in the next word. When used as the Span Memory 406 within the Span Sorting Renderer 500, the 
SMCCAM stores a set of spans and performs parallel searching and sorting operations to find the visible span portions. 

As shown in Figure 8, the data storage within the SMCCAM 800 is divided into SMCCAM Words 900, where each 
word 900 stores and processes (by performing query operations) data corresponding to one span in the current raster line. The 
figure shows a total of W SMCCAM Words 900, numbered 0 to KM. Each SMCCAM Word 900 includes seven numeric fields 
(and the variable name shown here is for the nth word): 1 ) the Word Number Held 802, w, that is a fixed (ijt^ read-only) unique 
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idcntifying number far each word 900, akin to «n address; 2) the Left X Field 804,^, that stores the x-coordinate of the left 
endpoint of a span; 3) the Left ZKeld8W >2jlL . that stores the incoordinate of the left endpoint of a span; 4) the Right 
X Held 80S, ^ thai stores the owwdinate of the right endpoint of a span; 5) the Right Z Field 810, 2,*, that stores the 
2-coordinate of the right endpoint of a span; 6) the Span Derivative Field812, d„ that stores the fiz/Er slope of the span; and 
7) the Information Pointer Field 814, i„, that stores a pointer into the Polygon Information Memory 514 for color information for 
the span's polygon. 

Each SMOCAM Word 900 also stores: 1 ) a Valid Flag 816, F„ v a tingle bit value indicating whether the SMCCAM 
Word 900 is storing valid data; and 2) * Query Flag 818. a single bit value indicating whether the SMCCAM Word 900 
responded positively to a query operation. Both flag bits 816, 818 each have a corresponding •Vired-nor" bus that indicates 
whether all words 900 have that flag bit turned off. Specifically, for the Valid Flag816\ F n y> if F mV is false for aUn (i.e„ all 
words), then the signal MWordslwaJid 990 is asserted. Similarly, if is false for aUn, then the signal 
NuUQueryRcsponse 992 is asserted. The two wired-nor signals, AJIWordslmaUd 990 and NullQwryResponse 992. provide the 
mechanism for query results to be fed back to the external controller (located in the Query Processcc510), so it can make deci- 
sions (Le, "branches) about how to proceed within the method. 

The nomenclature far fields and flags 804 to 818 include the Word Number Field 802 value as the first part of the field 
subscript (e.g„23L is in word 3). Later in this document, the number of fields in each word is increased to add various features to 
the Span Sorting Renderer 500. Figure 8 shows two variable word indices, n and w, that are used throughout this document as 
references to SMCCAM Words 900. 

A block diagram of an SMCCAM Word 900 is shown as Figure 9. where each of the seven fields 802 to 814 is shown. 
The seven fields, 804, 1^ 806. x^ R 808. z** 810, ^ 812, and v 814, each have a corresponding data bus within the set of 
Array Busses 910: BusW912, BusU.914. BusZL 916, BusXJl 918. WK920, BusD 922. and Bus! 924. Six of the 
fields 802 to 812 are broken into a memory 902 or 904 and a comparator 906 or 908. The Word Number Field 802 includes: I ) ■ 
fixed memory 902; and 2) an equality comparison circuit 906, used for query operations, that compares the fixed memory 
value 902 to the data on the input bus, BusW912. Five of the fields 804 to 812 include: 1) a read/write memory 904; and 2) an 
arithmetic comparison circuit 906 (tests for less-man, etc.), used for query operations, that compares the stored memory 
value 904 to the data on the corresponding input bus. The seventh field, the Information Pointer Field 814, is simply a 
read/write memory that does not generally participate in query operations. 

Query operations are used for searching, sorting, reading, and writing into the array 800 of SMCCAM Words 900. A 
query operation is performed by all SMCCAM Words 900 in parallel by supplying query data to all words 900 via the Array 
B usses 910. The SMCCAM 800 includes the Query Logic Array 850, which is a set of Query Logic 930 circuits, one in each 
SMCCAM Word 900. 

In parallel, within each SMCCAM Word 900, query operation results are computed by the Query Logic 930. The 
Query Logic 930 receives the results from the comparators 906 and 908 as well at the Valid Flag 816 and Query Flag 818 val- 
ues, performs a selectable Boolean operation on these values (selected by QueryCntrl 932) to generate a query result bit, and 
then writes the query result bit back into cither the Valid Flag 816 or the Query Flag 818. 

When a query operation is performed, every word 900 generates a query result, which is stored into either its 900 Valid 
Flag 816 or the Query Flag 818. The set of all Valid Rags 816 is called the Valid Flag Word 830, and the set of all Query 
Flags 818 is called the Valid Rag Word 834. When a search is done, the query results designate which words fulfilled the query 
operation parameters. An example query operation is: 

F *Q = F *V A (^hL^Cl) (EQ4) 



where the following occurs: 1) JfcL is broadcast to all words 900 via BtuZL 916; 2) the Left X Held 804 in each word 900 per- 
forms (x flL S * CL ) , by comparing its 804 contents, to the value on BusZL 916; 3) the Query Logic 930 in each word 900 
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pcrfbnns the right tide of Equation 4, which is the quay rault for Ihit word 900; 4) in each wwd 900. the quay result is stored 
into the Query Flag 818 shown as the left side of Equation 4; and 5) the tigjuLNxUQuery Response 992, i* asserted if the Query 
Flag 818 is false in all words 900. 

Additional example Boolean operand are ahem* in 
cast to afl SMCCAM Words 900 vU the Airay Bua^ 
place (this happens for all n, which means for all SMOCAM Words 900). 

F *Q = F *v* (»*5p) a (x^<x Ck ) a (x -R >x CL ) a[(: -l <2 cp ) v (z llR <z CF )] 
f .q bF .v^ iQ a [(*al<*cl> v (*.r<*cl>) 

F »Q = ^-V A (**L = X CR> a (**L = *CR> (EQ 5) 

The query operation mechanism inherently performs a search operation on the data stored in the SMCCAM800, and 
the search results are stored into the Query Flags 818. When data needs to be written into the SMCCAM800, the following 
sequence occurs: 1) the Valid Flag Word 830 (or. for certain applications, the Query Flag Word 834 could be used) is chosen to 
aetemiine the word 900 to be written; 2) the Valid Flag Word 830 contents are input to its 830 corresponding Priority 
Resolver 840; 3) the Priority Resolver 840 finds the first occurrence of a logic -zero- within the flag word 830. this is the first 
invalid word; 4) the SMCCAM Word 900 with the first occurence of logic "zero" is the selected word 900. and the data on the 
Array Busses 910 is stored into that word 900; and 5) the selected word 900 has its Valid Flag 816 asserted, indicating that word 
now contains valid data. 

A read operation works similarly, with the following sequence: 1) the Valid Query Flag Word 834 is chosen to deter- 
mine the word 900 to be read; 2) the Query Flag Word 834 contents are input to its 834 corresponding Priority Resolver 840; 
3) the Priority Resolver 840 finds the first occurrence of a logic "one" within the flag word 834; 4) the SMCCAM Word 900 with 
the first occurrence of logic "one" is the selected word 900. and its 900 contents are output onto the Array Busses 910; 5) the 
selected word 900 has its Query Flag 818 de-asserted, indicating that word has had its contents read, and subsequent reads (with- 
out intervening queries) will read other words; and 6) the signal NuUQueryResponse 992, is asserted if the Query Hag 818 is 
false in all words 900, indicating that no other words would respond to a read operation. The query, write, and read operations 
work somewhat similarly to that described in the Duluk Patent 

Hie portion of the Priority Resolver 840 within an SMCCAM Word 900 is called a Priority Resolver Section 934, and 
they 934 communicate across SMCCAM Words 900 via the busses: Va!idPriOullw-\] 936, QueryPriOut[y^\] 937, 
ValidPriOut\w] 938, and Query PriOul\w) 939. Alternatively, the Priority Resolver 840 could be built with a treelike structure, 
thereby making the worst case circuit propagation delay proportional to log W rather than W. 

The SMCCAM 800 also performs a sorting operation, which is not provided in the apparatus described in the Duluk 
Patent As described above, the Span Sorting RendererSOO sorts spans as they are written into the Span Memory 406 according 
to: 1) the left coordinate; 2) the lefti-coordinate; and 3) the span dewative. In the SMCCAM800. sorting is done by locating 
the place in the span list where a span needs to be inserted, then, from this place, shifting the SMCCAM 800 contents down one 
word 900, and then writing the new span into the vacated word 900. 

The SMCCAM 800 can shift data from word-to-word to make room in the sorted span list The sorting operation is 
done in the following sequence: 1) the geometric properties (as described above) of the span to be written are input to the 
SMCCAM 800 for a query operation; 2) the query operation of Equation 6 is performed in every SMCCAM Word 900 with the 
query results written into the Query Flags 818, thereby identifying all words that contain either invalid data or contain a span that 
should be sorted later in the span list that the span being written; 3) the Query Flag Word 834 contents are input to the corre- 
sponding Priority Resolver 840; 4) the Priority Resolver 840 finds the first occurrence of a logic -one" within the Query Flag 
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Word 834, thereby determining the selected word 900; 5) for the selected word 900 and all SMCCAM Words 900 after the 
^ected word 900, stared data u 
is stored into the word 900. 

Shifting data in the fields 802 to 814 from one SMCCAM Word 900 to the next is done via the Shift Id Busses 950 that 
axe connected to the Shift Out Busses 970 of the previous word 900. The list of Shift In Busses 950 includes: 
ShifiOuXlW-l]9S* ShifiOuXRl»-l}9S4; ShjftO*m~-l)*S6; ShiftOMtZSlw-l]9SS; ShiftOulDl^l) 960; and 
ShifiOmllM^l) 961 The list of Shift Out Busses 970 includes: ShifiOuXHw) 972; ShifiOxXX[w] 974; ShiflOuWiw) 976; 
ShifiOuiZXlw) 978; SMftOiaD[w-\] 980; and ShifiOulI[w} 982. The circuit signal nonienclalure used in this document includes 
the use of a bracketed index, such as >] M , indicating it is part of an array of busses (siinilar to the amy nomenclature of the "C" 
computer language). Here, >f mdicates the wth word 900, and "[h-I]- indicates the word 900 iimnediately prior in the set of 
words 800. 
Span Occluding Test 

Figure 10 shows three spans 1002, 1004, 1006 represented by line segments (Lc. "segment spans") in the*-* plane, 
corresponding to one raster line of the display screen 104. One of the spans 1002 is shown with a corresponding Occluding 
Region 1008. If there are no spans that Occluding Region 1008, then the corresponding span 1002 is not bidden. The shape of 
the Occluding Region 1008 is trapezoidal, and therefore it is computationally expensive to Determine if another span lies within 
it 1008, and is particularly expensive if many spans need to tested against the region 1008. A simplifying approximation for an 
Occluding Region 1008 is a rectangular Span Occluding Test Region 1010 (hereinafter called an SOT Region 1010). The SOT 
Region 1010 is generated from the span (or span portion) being tested for occlusion, hereinafter called the Current Portion, 
S c 1004. Determining if a span 1006 with endpoints (x^, z*) and (x^ z^ lies within an SOT Region 1010 for a Current Por- 
tioa 1004, 5 C . with endpoints (j^, zq) 1012 and (x^, zat) 1014 is done by: 

In SOT Region = ( x^ < x CR ) a (x -r > x CL ) a [ ( 2-L < MaxOf(z CR , x CL ) ) v (z mR < MaxOf(z CRf z^) ) ) (EQ 7) 

The arithmetic computation required for Equation 7 is four comparisons and one w cAoose4hc-niaximum-or function (the two 
needed in the equation are identical). For the SMCCAM 800 to perform the operations of Equation 7. the "choose-me-maxi- 
mum-of * would be performed outside the SMCCAM 800 to determine: 

2 CF = MaxOf (Z CR , 2 CL ) (EQ8) 

and then the values x^, and Zcf would be input on the Array Busses 910 and the comparisons would be performed in the 
appropriate fields 804 to 810. In this way, all the spans stored in the SMCCAM 800 would be tested in parallel, performing the 
search for occluding spans in a matter of nanoseconds. In this document, any span that is found by an SOT Query is called an 
occluding span. 

The complete equation for the Span Occluding Test Query (hereinafter called the SOT Query) is shown as Equation 9. 
F .Q * F *V A <"* S P> * (*„L <JC CR> A <**R >jr CL) A I (*«L<*CF> V < Z .R<*CF>1 (EQ 9) 

The complete SOT Query equation adds two more terms to the conjunction: 1) the Valid Flag816, needed to keep words with 
invalid data from mistakenly identifying themselves as storing an occluding span; and 2) a test,** J,* where 5 P is the Word 
Number Field 802 corresponding to the Current Portion, done to keep the span from being identified as occluding itself. The 
complete SOT Query equation stores the query result into the Query Flag 818 of each SMCCAM Word 900. The result of the 
SOT Query is available at the signal NullQuery Response 992, where an asserted value indicates that no occluding spans < 
found. 
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By using the SOT Region as an approximation of the Occluding Region 1008, a conservative error is introduced. That 
is, the SOT Query may find occluding spans that are within the SOT Region 1010, but are actually behind the Current Portion. 
However, the SOT Query will never fail to find spans that actually occlude the Current Portao n. 
Span Sorting Rendering Method 1300 

In order for the SOT Query to inadvertently find an occluding span that does not actually occlude the Current Portion, 
the bounding box (described in the next section) of the Current Portion must overlap the bounding box of the occluding span. 
Therefore, the simplest form of the Span Sorting Rendering Method 1300 assumes that bounding boxes of spans do not overlap, 
thereby eliminating the need to handle occluding spans that do not actually occlude the Current Portion. While this assumption is 
not practical for most rendering applications, it does simplify part of the description of the method 1300. Therefore, this simpli- 
fied (though not generally practical) version will be described first In a later section, the method 1300 will be expanded to pro- 
cess spans with overlapping bounding boxes. 

Figure 11 shows a set of fourteen spans in the same raster line (numbered 5 0 1100 to S 13 1113), where each span is 
represented by a line segment in the x-z plane of the raster line (the v-coordinate is fixed). The visible parts of the spans are 
shown as thick lines, and the hidden parts are shown as thin lines. For example,^ 1104 and S 6 1106 are hidden, and S 0 1100 has 
two visible portions. The spans have been sorted according to wex-coordinate location of their left endpoinL Hence, the spans 
are numbered from left to right according to their Word Number Field 802 assigned when they are all stored in the 
SMCCAM 800. For example, span 5 4 1 104 it stored in SMCCAM Word 900 number four, and has its left endpoint located at the 
point (*4 L , 2 4L ) and its right endpoint located at (x 4R , i^g). 

Figure 12 shows the same fourteen spans, except that each span is enclosed by a bounding box. The set of spans in 
Figure 11 and Figure 12 were chosen to that the span bounding boxes do not overlap. The spans of Figure 12 will be used to 
describe the simplest form of the Span Sorting Rendering Method 1300, the version that includes the Simplified Span Rasteriza. 
lion Method 1800 which assumes span bounding boxes do not overlap. 

The Span Sorting Rendering Method 1300 is described in the context of the apparatus described herein, but can also be 
performed by software on a general purpose computer. Figure 13 is the top-level method diagram of the Span Sorting Rendering 
Method 1300. This method 1300 is performed by the Span Sorting Rendering Pipeline 400 of Figure 4, in the same way the 
method flow diagram 300 of Figure 3 is performed by the generic 3D graphics pipeline 200. 

In the Span Sorting Rendering Method 1300, scenes are generated 1302 (object locations in world coordinates, etc.), 
and within each scene, polygons are obtained 1304 for input to the Span Sorting Rendering Pipeline 400 and processed 1400. 

Figure 14 shows the process polygon step 1400. Included are the previously described transformation 202, clip 
test 204, face determination 206, lighting 208, perspective divide 212 and compute polygon parameter 402 steps. After these 
steps, polygons are written into the Bucket Sort Memory 404, each according to its ysTAKT parameter. 

Getting back to Figure 13. once all 1306 the polygons for a scene have been processed 1400 and therefore written into 
the Bucket Sort Memory 404, each raster line is processed. The variable,*, is used to keep track of the current raster line num- 
ber, and is initialized 1308 to zero. Before the first raster line can be processed, the Current Polygon Memory 406 must be 
cleared 1310, thereby indicating that no polygons are on the current raster line. Also, the Span Memory 408 must be 
cleared 1312, thereby indicating that no spans are on the current raster line. These operations 1310, 1312 can be done by mark- 
ing the entire contents of the memories 406, 408 as invalid. Since, at the first raster line, there are no polygons in the Current 
Polygon Memory 406, the next step 1600 is to transfer polygons that start in the current raster line form the Bucket Sort 
Memory 404 to the Current Polygon Memory 406 and to make spans for these polygons. Beginning on the second raster line 
(i.e„ R « 1), there is probably some polygons in the Current Polygon Memory 406, and spans need to be made 1500 for those 
polygons. 

Figure 15 is the Process Current Polygon Memory 406 step 1500 within the Span Sorting Rendering Method 1300. 
Each 1502 polygon in the Current Polygon Memory 406, is read 1504, and if 1506 that polygon is not included in the current 
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raster line, it is deleted IS08 from the Carat Polygon Memory 406 so subsequent raster lines do oot need to consider it If 1506 
the polygon is included in the present raster line, then a span within the current raster line and its Span Parameters (as described 
above) are generated 1510 for that polygon. Then, the Span Parameters are written 1700 into the Spaa Memory 408. 

Kgure 16 is the Process Bucket Sort Memory 404 step 1600 within the Span Sorting Rendering Method 1300. If 1602 
there are more polygons to be read from the Bucket Sort Memory 404 for the current raster line, then for each such polygon: 
l)the polygon is read 1604 from the Bucket Sort Memory 404; 2) the polygon is written 1606 into the Current Polygon 
Memory 406; 3) the polygon has a span in the current raster line, and Span Parameters (as described above) are generated 1510 
for the span; and 4) the Span Parameters are written 1700 into the Span Memory 408. 

When writing 1700 Span Parameters into the Span Memory 408, a sort operation is done. The sort operation is per* 
formed by the SMCCAM800 as a query operation (Equation 6) and a special write operation, as described above. The apparatus 
of the SMCCAM800 performs this step 1700 in parallel but it is described in the flow diagram 1700 of Figure 17 as if it is a 
sequential search process. A counter, n, used as an index into the set of SMCCAM Words 900, is initialized 1702 to zero. The 
flow diagram shows the query operation of Equation 6 broken down into six conditionals 1704 that test to see if the new span 
should be inserted at the nth word 900. Words 900 are stepped through 1706 by incrementing n until such an insertion point is 
found. When the insertion point is found, the counter n stops incrementing, and the contents of all the words from W- 1 to n 
(using the counter, m) are transferred 1708 to the next word and the Span Parameters are written 1710 into word n. A test 1712 
for reaching the last word 900 (i.e.. word W- 1) is included to detect an exception 1714 condition if there are more than a total 
of W spans in the raster line, thus exceeding the total number of words 900. Strategies to work within a fixed number of 
words 900 are presented later in this document 

Once again returning to Figure 13. once all the spans within the display screen at raster line J? have been written into 
the Span Memory 408, visible span portions are identified 1800 or 2100. One version of this portion of the method is the Simpli - 
fied Span Rasterization Method 1800, which assumes span bounding boxes do not overlap. Other versions that do not make this 
assumption are the Segment Span Rasterization Method 2100 and the Trapezoidal Span Rasterization Method, described in later 
sections. 

Simplified Span Rasterization Method 1800 

The Simplified Span Rasterization Method 1800, shown in Figure 18. maintains three sets of variables: 1) the current 
left ^-coordinate position, *cl» used to indicate how much of the current raster line has been rendered so far, 2) the Present Span, 
S P used to keep track of the frontmost span atx<x, including its Span Parameters*^, z^ xpR, zpR, dp i> and word number, and 
3) the New Span, 5 N , used to keep track of the span most recently read form the Span Memory 408 (generally found by a query), 
including its Span Parameters x^ z^, z^ d H , i N , and word number. In the Simplified Span Rasterization Method 1800. 
the Current Portion, S c , is always equal to the Present Span,5p, 

The rasterization method 1800 will be explained by using the set of spans in Figure 12 as an example. In the rest of this 
section, the method 1800 will be followed step-by-step as the example spans are processed. 

The method 1800 starts by setting 1802 Xq, to zero (thereby starting at the left edge of the display screen) and declar- 
ing the variables S P and 5 N to be invalid. Because £p is invalid 1804 and there are valid 1806 spans still stored in the Span 
Memory 408, a search 1808 must be done to find either the frontmost span HXq, (*•*•• zm ) if there is no span sj*cl* then 
find the leftmost valid span in the Span Memory 408. 

The first step in this search 1808 is to do a query 1810 to find all valid spans in the Span Memory 408 that include Xq^ 
(Le., zero). Looking at Figure 12, it is seen that there are no 1812 spans at x-coordinate zero (the query 1810 finds nothing). 
Because there are no spans 1812 at x-coordinate zero, the leftmost span in the Span Memory 408 (Le^ the first valid span 
because the spans are sorted) is read 1818 thereby making 5 P to be equal to £ 0 1200. There were no valid spans at 
*CL zero), and the leftmost span does not start until Xq^ (left endpoint of span S 0 1200), so the range from zero to Xql does 
not have any spans at all, and therefore the background is rendered 1820 from x^ (Lc, zero) to x^. Some rendering has been 
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done, w the valnc fw^ is tnjdited 1822 to 

Queiy is done 1824 for the Present Span fix, «S 0 1200) to find any occluding spans, and this finds all the other spans 1201 
to 1213 since they are all in the SOT Region of 5q 1200. Hie first of these found spans are read 1824, making the value of the 
New Span, S N . equal to S x 120L 

Toe method 1800 has not reached 1826 the right edge of the display screen 0^x cx <i MAX ), both 5 P and 5 N are 
valid 18M «id 1828, and the next step 1^ 

ing can be done because the SOT Query 1824 found the leftmost occluding span m front of S 0 1200, meaning any part of 
S 0 1200 to the left of this occludmg span must be visible 

also makes S N (Lc„ 5, 1201) into the new value of Sp, An SOT Query is done 1832 for the Present Span (Le„ S x 1201) to find 
any occluding spans, and this finds only one span,S 2 1202, since it 1202 is the only span in the SOT Region of 5, 1201. This 
span is read 1832. making the value of the New Span, S N , equal to S 2 1202. 

The span S x 1201 is processed in a way similar to 5 0 1200. The method 1800 has not reached 1826 the right edge of 
the display screen (Le,o CL < J r MAX ), both S P andS N are valid 1804 and 1828, andSp (Le.,S, 1201) is rendered 1830 from 
*CX *1L> to *NL <Lc, *2I> The value for xq. is iipdaied 1830 to be fix. x^), and S N fi*., S 2 1302) is made into the 
new value of An SOT Query is done 1832 for the Present Span (Le^5 2 1202X but the query does not find any spans because 
nothing occludes Sj 1202. and the value of the New Span, 5 N . is set to invalid. 

The right edge of the display screen has not been reached 1826, 5 P is valid 1804, S s is invalid 1828, and the next 
portion 1834 of the method 1800 includes a search for an abutting span for S P An abutting span is a span whose left endpoint is 
located at the same point as the right endpoint of the Current Portion (or. for the Simplified Span Rasterization Method 1800, the 
Present Span). In Figure 12, three example pairs of abutting spans are: l)S 2 1202 and 5, 1205; 2)5 5 1205 and 5 7 1207; and 
3) S 6 1206 and S 9 1209. Abutting spans occur frequently because 3D objects are generally described by a set of polygons that 
share edges. Therefore, for highly tessellated objects, most spans will be part of at least one abutting span pair. 

The portion 1834 of the method 1800 starts with rendering 1836 S P (Le., 5 2 1202) from xcl<^*2l) to 
*pr (Lc^r). This can be done because the SOT Query did not find any occluding spans, thus proving S P fix., S 2 1202) is not 
hidden at all. and should be rendered. Also, XcL is set 1836 to (Le„ *»). Next, a query is done 1838 to find an abutting span 
for S P (Le„ S 2 1202). which finds span S 5 1205. Because 1840 an abutting span was found, the abutting span, S 5 1205, is 
read 1846 and assigned to 5 P An SOT Query is done 1848 for the Present Span (Lc.S 3 1205), but the query does not find any 
spans because nothing occludes S 5 1205, and the value of the New Span, S N . is set to invalid. 

The Present Span, S 3 1205, is processed similarly to S 2 1202. The right edge of the display screen has not been 
reached 1826. 5 P is valid 1804. S s is invalid 1828. S P ft*. S 5 1205) is rendered 1836 from x^ (Le. x^) to fix. x^X and 
*CL is set 1836 to *pr (Le„ *sr). A query is done 1838 for an abutting span, which finds span S 7 1207. The abutting span, 
S 7 1207, is read 1846 and assigned to 5 P An SOT Query is done 1848 for the Present Span (Le„ S 7 1207), finding only S t 1208 
which is read 1832, making the value of the 5 N equal to S g 1208. 

Tne Present Span, 5 7 1207 is processed similarly to S x 1201. The right edge of the display screen has not been 
reached 1826, both S ? and are valid 1804 and 1828, and Sp fix. S 7 1207) i, rendered 1830 from xcl^^sr) to 
JfNLO^JtgL). The value for*cL is updated 1830 to be (Le., x^ and Sp is set to S s (Le., S 2 1202). An SOT Query is 
done 1832 for the Present Span (Le., 5 8 1208), but the query does not find any spans, and the value of the New Span, 5 N , is set to 
invalid. 

Tne Present Span, S B 1208 is processed similarly to Sj 1202 and S 5 1205. The right edge of the display screen has not 
been reached 1826. 5 P is valid 1804. 5 H is invalid 1828, S P (i^ 5 g 1208) is rendered 1836 from x^ (Le.. xgj to x^ (Le., x^ 
and b set 1836 to XpR (l^, x^g). A query is done 1838 for an abutting span, which finds span S 10 1210. The abutting span, 
S l0 1210. is read 1846 and assigned to Sp An SOT Query is done 1848 for the Present Span (Le„S 10 1210), but the query does 
not find any spans, and the value of the New Span,5 N , is set to invalid. 
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As the Present Span, S 10 1210 is processed, the search far an abutting span doei aot find such a span. Ibe right edge of 
the display screen has not been reached 1826, 5 P is valid 1804, S# is invalid 1828, Sp fix, S l0 U10) is rendered 1836 from 
*CL (i.«^*8R) to*PR frc-,x iaR ), and jccl is set 1836 toxpR (Le^x 10R ).A query is done 1838 far an abutting span, but no abutting 
span is found. Since 1840 no abutting span was found, a search must be done to find the frontniost span atx^ ^ 
ever, before the search is done, a query is done to invalidate 1842 all spans that are completely to the left of (Le^x 10R ).This 
invalidation 1842 can be done became the current raster line has been rendered up tox^iU^x^ and spans to the left of 
*CL *ior) were either rendered or hidden (or some of each). The invalidation 1842 turns off the Valid Rags 816 fox S { 1201 
through S l0 1210, thereby leaving only S 0 1200 andS n 1211 through S 13 1213 as validly stored spans. The value of the Present 
Span, 5 N , and the value of the New Span, £ N , are both set 1844 to invalid. 

The right edge of the display screen has not been reached 1826, 5 P is invalid 1*04, there are soil 1806 valid spans, and 
the next part 1808 of the method uvOudes a searcn for the frontal 

spans that include Xq. (It, jt 10 rX which finds two spans: 5 0 1200 and 5„ 1211. Since 1812 spans were found, these two 
spans 1200 and 1211 are read 1814, the z-coordinates of the spans are computed 1814 at Xq, (i^ x 10R ), and are compared to 
determine 1814 that S n 1211 is the fiontmost span. The coordinate computation is simplified by having the span derivative 
(from the Span Derivative Field 812) available for use in extrapolating from the left endpoint of the span. The frontmost span, 
S„ 1211. is made 1814 the Present Span, S P An SOT Query is done 1824 for the Present Span (Lc.S n 1211), but the query 
does not find any spans, and the value of the New Span*5 N , is set to invalid. 

The Present Span, S n 1211, is processed similarly to S 2 1202, 5 5 1205, and S 9 1208. The right edge of the display 
screen has not been reached 1826, S ? is valid 1804, S# is invalid 1828, S f (Le. S„ 1211) is rendered 1836 from xq. (i.e„ x 10R ) 
to *pr (Lc, x llR ), and xq, is set 1836 to x ra (Le, x 1UL ). A query is done 1838 for an abutting span, which finds span S l2 1212. 
The abutting span, S 12 1212, is read 1846 and assigned to 5 P An SOT Query is done 1848 for the Present Span (U„ S l2 1212), 
but the query does not find any spans, and the value of the New Span, 5 N , is set to invalid 

The Present Span. 5 l7 1212 is processed similarly to S l0 1210. The right edge of the display screen has not been 
reached 1826. S ? is valid 1804, S s is invalid 1828. S ? (Le.,S n 1212) is rendered 1836 from Xq. (Le^ x llR ) to x,* (Le^ x l2R X 
and x^ is set 1836 to x PK (Le., x m ). A query is done 1838 for an abutting spaa but no abutting span is found. Since 1840 no 
abutting span was found, a query is done to invalidate 1842 all spans that are completely to the left of X&, (Le„ x 13R ). thereby 
turning off the Valid Flags 816 forS n 1211 and 5 U 1212, thereby leaving only S 0 1200 and S i3 1213 as validly stored spans. 
The value of the Present Span, 5 K , and the value of the New Span, 5 N , are both set 1844 to invalid. 

The right edge of the display screen has not been reached 1826, 5 P is invalid 1804, there are still 1806 valid spans, and 
the next part 1808 of the method includes a search for the frontmost span atx^ (Le., jr 12R ). First, a query 1810 is done to find all 
spans that include x^ (ix„ x 12R X which finds only one span, Sq 1200. Since 1812 a span was found, it is made 1814 the Present 
Span, S P An SOT Query is done 1848 for the Present Span (Le^ S 0 1200X finding only S 13 1213 which is read 1832, making the 
value of the5 N equal to S l3 1213. 

The right edge of the display screen has not been reached 1826, both S P and£ N are valid 1804 and 1828, and S ? 
(i.e., S 0 1200) is rendered 1830 from x^ G-e., x 12R ) to x^ (U„ x^). The value for x^ is updated 1830 to be x^ (Le„ x 13L ), 
and Sp is set to S N (i^ S 13 1213). An SOT Query is done 1832 for the Present Span (Le^ S 13 1213), but the query does not find 
any spans, and the value of the New Span, 5 N . is set to invalid. 

The right edge of the display screen has not been reached 1826, 5 P is valid 1804, S u is invalid 1828, S ? (ut^ S u 1213) 
is rendered 1836 from *cl ftc x 13L ) to x,* (i^ x 13R X and xq. is set 1836 to xj* (Le.. x m ). A query is done 1838 for an abut, 
ting span, but no abutting span is found Since 1840 no abutting span was found, a query is done to invalidate 1842 all spans that 
are completely to the left of x^ (Le„ x m ), thereby turning off the Valid Flags 816 for 5 0 1200 and S 13 1213. thereby eliminat- 
ing the last valid spans. The value of the Present Span, £ N , and the value of the New Span, S N , are both set 1844 to invalid. 

The right edge of the display screen has not been reached 1826, S ? is invalid 1804, and there are 1806 no valid spans. 
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Therefore, the background is rendered from x^ (Le^ x^) to j^ax (i-Ohe right edge of the raster line). The entire current ras- 
ter line has now been rendered, and the next raster Hoe cm be processed, as shown in the method flow diagram of Figure 13. 

It is important to note that the method 1800 rendered the visible portions of the spans, and completely ignored the 
spans that are totally hidden (Lew S 3 1203, S 4 1204, S 6 1206, and 5 9 1209). For scenes with greater depth complexity, a larger 
5 fraction of the spans will be ignored m a siniilar way, thereby providing > greater cnmpitiKnnal savings. A uiiique feature of this 
method 1800 is the ability of abutting spans to work together to occlude spans behind them. 

Another important feature of the method 1800 is the pixel coloration processing within a raster line is roughly propor- 
tional to the number of pixels in the raster line, rather than proportional to the number of pixels in all the spans in the raster line. 
This is because hidden portions within spans are never sent to the pixel coloration process. Pixel coloration processing is 
10 "roughly** proportional to the number of pixels within the raster line because a pixel can be affected by two spans because, for 
example, the span to the right may end within the pixel's boundary. In this case, color from two spans are blended together to 
form the final color for the pixel. 

Span Interaction Types and Span Interaction Parameters 

As described above, the SOT Query is a set of comparison operations simple enough to be performed in hardware by 

1 5 an SMCCAM 800. However, in the general case where span bounding boxes overlap, the SOT Query will sometimes find spans 
thai do not occlude the Current Portion. Furthermore, the SOT Query will also sometimes find spans that intersect the Curreni 
Portion, thus making both spans partially visible. The Segment Span Rasterization Method2100 solves this shortcoming by cat- 
egorizing the interaction between the Current Portion and a span in the SOT Region into one of many Span Interaction Types 
(hereinafter abbreviated SIT), and then applying rendering rules based on the SIT. The SIT is determined from the Span Interac- 

20 tion Parameters (hereinafter SIP) of the two spans. 

As the Segment Span Rasterization Method 2100 proceeds, it 2100 maintains four spans and their fff^ i at H parame- 
ters: 1 ) the Present Span, the frontmost span atx^, as described above; 2) the New Span, 5 N , a span in the SOT Region ofS p 
as described above; 3 ) the Current Portion. a subsection of the Present Span, Sp; and 4) the Saved Span, 5 S , used as a single 
depth stack for temporarily saving 5 N so that more spans in the SOT Region ofSp can be read. 

25 The nomenclature for spans, span endpoints, SIPs, and SITs is illustrated by the examples shown in Figure 19. The 

Present Span. S ? 1902. has the endpoints (x^ zpj 1904, 1906 and (xpg. if*) 1908, 1910. is enclosed by a dashed oval and is 
shown as the union of a solid black line and a finely dotted line. The solid black line subsection ofS P 1902 is the Current Portion, 
S c 1912. and has the endpoints (xq.. zqJ 1914, 1916 and (*<*, Z&) 1918, 1920. The SOT Region 1922 corresponding to 
$c 1912 is enclosed by a dashed line. The New Span, 5 N 1932. has the endpoints (*nl» 2 nl) 1954 » 1W 6 and 

30 (xnr, inr) 1938, 1940, and is enclosed by its bounding box 1941 

The Span Interaction Parameters (U„ SIPs) are arithmetic comparison results between thcz<oordinates of S c 1912 
and S s 1932 at four particular x-coordinate values, specifically, the endpoints of the two spans: 1934, jt^r 1938, Xq, 1914, 
and Xqr 1918. In detailed terms, the four Span Interaction Parameters (Le., SIPs) are: 1) the comparison of thez-coordinate of 
5 C 1912 at XtfL 1934 to 1936, shown in the example as "Nonexistent" because S c 1912 does not have a point atx^ 1934; 

35 2) the comparison of the i-coordinate of S c 1912 atx^ 1938 to 2 m 1940, shown in the example as "Farther" because the point 
on S c 1912 is father (Le„ has a greater *<oordinate) than 2 M 1940; 3) the comparison of the z-coordinate of 5 H 1932 at 
*CL 1914 to 1916, shown in the example as "Farther** because the point onS N 1932 is father (ix., has a greater 2<c<mtinate) 
than zq, 1916; and 4) the comparison of thez<oordinate of S N 1932 atx^ 1918 to zq 1920, shown in the example as ''Nonex- 
istent** because 5 N 1932 does not have a point atx^ 1918. Each of the four SIPs can take on one of the values: 1) "Nonexistent" 

40 (abbreviated "Non"); 2) "Farther" (abbreviated "Far"); 3) "Nearer" (abbreviated "Near"); or 4) "Equal". In the example of 
Figure 19, the four SIPs are Non, Far, Far, Non, as shown in the figure. This particular set of four is SIT 23, causing invocation of 
Rule 4, as will be described later in this document. 

The SIPs were chosen so as to be easy to compute, avoiding expensive computations such as division. The compute- 
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z-coordinatc of S Q at x } 
z-coordinate of S c six l 
z-cooidinate of 5 N at x ( 
z-coordinatc of S K at x t 
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CL 



NL 



Z CL + ^NL-^CL)^ 
Z CL + ^ X HR' X a) d C 
2 NL + ^ X CL^ X m) d S 
2 NL + ^CR"^^ 



(EQ10) 



Figure 20 is & listing of all 49 possible SITs. For example. Figure 20C illustrates SIT 3, showing three examples of a 
5 C paired with an 5 N> where the SIPs are Near, Equal Non, Non. Each possible combination of SIPs correspond to one SIT. 
When a particular SIT is encountered during the Segment Span Rasterization Method2100. one of several rules is invoked, and 
each SIT in Figure 20 identifies the rule it invokes. Some SITs, such as SIT 19 and SIT 22, cannot ever be encountered by the 
method 2100, therefore, no rule is invoked, and the tag "impossible- is shown in Figure 20. 
Segment Span Rasterization Method 2100 

The Segment Span Rasterization Method 2100, shown in Figure 21, processes spans that are represented by line seg- 
ments (as in Figure 7 A). This method can be utilized within Span Sorting Rendering Method 1300, shown in Figure 13. In this 
section of the document, the method flow diagrams of Figure 21 through Figure 26 will be described in very general terms. In the 
next section, an complex set of example spans is used to describe the step-by-step functioning of the method2100. 

The Segment Span Rasterization Method 2100 starts by initializing 2102 and 2104 variables. The method 2100 calls 
sub-methods, called Rule 1 2200 through Rule 5 2600. Every rule considers: 1) what part of 5 C should be rendered, if any; 2) the 
updating of 5p and/or 5 C ; 3) updating of 5 S ; 4) invalidation of spans stored in the Span Memory 408; 5) doing an SOT Query; 
and/or 6) updating of 5 N . 

Rule 1 2200 (shown in Figure 22) is invoked if 5 P is invalid. It 2200 searches for the frontmost span at j^, makes the 
frontmost span 5^ performs an SOT Query, and updates 5 N . 

Rule 2 2300 (shown in Figure 23) is invoked if S c has no Potentially Occluding Spans remaining. Therefore, 

it 2300 renders the Present Span, s» from x^ to j^. Then, s c is set to, in order of precedence: 
1) the Saved Span, s s ; 2) an Abutting Span; or 3) die first valid span after invalidation of all 
spans completely to the left of j^r. In any case, x^ is set to j<cr, and s s is invalidated. 

Rule 3 2400 (shown in Figure 24) is invoked if the SIT is such that the Current Portion, 5c is Occluded at 

*kl, but is visible from to XsL . Therefore, render the Present Span, 5^ from *cl to *nl- Then, 
make the New Span, 5 N , the Present Span and begin processing it Since s c is not being rendered 
to jccr, invalidate the Saved Span, s s . 

Rule 4 2500 (shown in Figure 25) is invoked if the SIT is such that5 c intersects 5 N and the point of intersection is vis- 
ible. The intersection point, at (x If z x \ between the Current Portion, 5c and the New Span, 5 N is com- 
puted. Since 5 C is occluded to the right of x h 5c is modified by changing ^ to The New Span, 
5 N , is stored as the Saved Span, 5 S , in case it is needed later under Rule 1 2200. Then, the next 
Potentially Occluding Span is read and made 5 N . 

Rule 5 2600 (shown in Figure 26) is invoked if die Current Portion, S& occludes the New Span, 5 N , 
such that none of 5 N is visible from xq. to x^. Therefore, 5 N is discarded, and the next Potentially 
Occluding Span is read and made 5 N . Since 5 C is not being rendered when this rule is applied, 
leave the status of the Saved Span, 5 S , unchanged. 

Detailed example of the Segment Span Rasterization Method 2t 00 

In order to fully describe the Segment Span Rasterization Method 21 00 in a step-by-step fashion, an example set of 
fifteen spans, shown in Figure 27, is used to illustrate how the method 21 00 wc^ The spans u this example were chosen so as 
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to exercise all parts of the Segment Span R««tti«tioo Method 21 00. Tlicei^le, when 

ical Miie^ u *bw»nn«Iry coinplex itae to tte 

in Uw Segmc« Span Ristcrizttkm Methcrf2100 » 

gran» «re li«ted it the begbmng of the ilep 4 

•s they appear in the method flow diagrams, then, on a second line, the tame equation is shown with all iti variables substituted 1 
by value* from the example of Figure 27. Ala within a step Ascription, alignment statements will be cascaded (with multiple 
"=" signs) showing how to arrive at the fully substituted variables. 

rbrtte example of Figure 27, whrau« Segment 
in the SMCCAM 800. designated S D through S u . These spans are stored in SMCCAM Words 800 0 through 14, and therefore 
each have (f. v = l). indicating those SMCCAM Word, BOO l*ve valid contents. The rest of the SMCCAM Words 800. namely 
words 15 through W - 1, each tave (f„ v - o). indicating those SMCCAM Words 800 have invalid contents. Hence, at the start 
of the Segment Spaa Rasterization Method 21 00. the Valid Flag Word 840. F v designates the set of valid .pans, and this set is 
not empty. 

For the example set of fifteen spans shown in Figure 27. the siep-by -step processing using the Segment Span Raster- 
ization Method 2100 is: 

1) 2102 The kit, value of the Current Portion,^ indicates how far the rendering has proceeded along the present 
raster line. Hence, the start of .raster line «»u»es setting^- 0).TT*left2 value of the Current Portion, ^ is 
set to infinity to allow any span to be in front of the background. The depth lexation of the background is 
considered to be .1 infinity. The background is not composed of polygons, and for may applicaiioni, is set to the 
color blacL Tbe right x «td y valties o 

valid Present Span, S P With assignment statements, this is described as: 

*cl ° 0; *cr e invalid; 
2cl * infinity; i CR = invalid; ^ n) 

2 CF s infinity; 

2) 21 04 The data within registers for staring span mformation external to the SMCCAM 800 (Le, S h S N , and S s ) are 

also designated as invalid. 

Sp «= invalid; 
S H "invUid; 
S s = invalid; 

3) 2106, 21 08, and 2200 Because the Present Span. is not valid and F v is not empty findicating that »t least some 

•pans are valid). Rule 1 is invoked. Here. Rule 1 is used to ieuchfortheDjaspantoinatethePrese«Sp«v5p 
3A) 2202 Do a query to find all valid spans that could affect the current raster line at (u, at 
x coordinate zero). The query performs, in each SMCCAM Word 800: 

'.q^vaKlSO) «»> 

This query does not find any aparis, and therefor^ 
3B) 2204, 2206, and 2208 Because F Q is empty and 5 P is not valid, there must not be a valid span that 
could affect the current raster line at x^. Therefore, the first span in F v is read and made the Present 
Span. .Sp This read operation sets the following values: 
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5 p = read (a) «= 0; 

jf pL = read^) «= jt ol ; = remtKxg) = * 0R ; 

« * » x (EQ14) 

ipL * read^) = z 0L ; i pR = read(i R ) = z 0R ; 

<f p = read (J) « rf 0 ; ip = read(i) = i 0 ; 

5 

Reading the first spin from Fy yields the leftmost valid span, became the spans are stored in the 

SMCCAM 800 in a kft to right ordering. 
3C) 221 0 Because there is not a valid span thai could affect the current raster line atx^ (Le„ at x coordinate 

zero), and the leftmost valid span docs not start until JEpi/Le^ *olX the background must be rendered 
1 0 from xq, to *pl (Le*, from 0 to x^). 

As possible alternate methods, rendering of the background can be avoided if: 1) it is know that 

polygons will always cover 100% of the viewing plane; or 2) the raster buffer is initialized with the 

background colors prior to processing the first span in each raster line. 
3D) 221 2 There is now a Present Span, 5 P (Le„ 5 0 X nd the Current Portion, 5 0 is set equal to 5 P by setting : 



15 



35 



*0L» 

Z CL c 2 PL = *0L ; *CR s *PR * *0R ; (EQ 15) 

CF * »**Up L 'W = m«(*oi/ 2 OR> = *ojJ 

The Current Portion, 5 0 is equal to 5q. The Far Z Value for the Current Portion, Zq; is set to Iql by the 
20 "find the maximum** function. 

3E) 221 4 There is now a defined Present Span, 5 P (Le^ Sq). and a defined Current Portion, S c (Le„ S 0 \to* 
search is done for spans that could possibly occlude the Current Portion, S c , (Lc, S 0 \ The Span 
- Occluding Test query performs, in each SMCCAM Word 900: 

= F „V A C»* V A U |lL <Jt CR ) A (X ||R >X CL ) A [ (2 -L <Z C p) V (Z )|R <2 cp )] 
25 s f ,V A <»*°) A (^<* 0 r) a (*.R>*0l) A I( J «L <2 01.) V <*i.R<*bL>l ^ 

This query creates the set of all Potentially Occluding Spans for the Current Portion, 5 C (i.e., 5 0 ). The 
query finds 5j through S 14 . In general, queries used for search operations include F n v in the conjunction 
in order to prevent invalid data stored in a SMCCAM Word 000 from causing a bit in Fq from being 
30 mistakenly asserted. 

3F) 2216 and 2218 Because Fq is not empty, there must spans that possibly occlude the Current Portion, 
Sq (le,, 5 0 ). Therefore, the first span in Fq is read and made the New Span, 5^. This read operation sets 
the following values: 

5 N = read(n) = 1; 
x Kh = read(x L ) = x a ; x NR = read(x R ) = * lR ; 

-KL - «**<*L> * 2 lLi 3 NR c «ad(2 R ) « * lR ; 

</ N s read(rf) = rfjj * N = read(i) = i x ; 

Reading the first span in Fq yields S\, the first span in the set The read process also deletes £ 2 from Fq 
40 by setting (FjqsO). 

4) 21 09, 21 06, 21 1 0, and 21 1 2 The right edge of the display screen has not been reached (ijt^x^ < j^ 1T ) and both 
the Present Span, S P (Le., S 0 \ and the New Span, 5 N (i.e.,5]), are valid. Therefore, the Span Interaction 
Parameters for these two spans are computed, and are found to be: (Far, Non, Non, Far). 
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5) 211 4 The Span Interaction Type is determined from the Span Interaction Parameters, and turns out to be Type 14. 

6) 21 1 6 and 2400 Because the Span bteractioa Type is Type 14, Rule 3 invoked Id process S©: 

6A) 2402 Hie Current Portion. S c (Le. t is hidden starting at x^ (Le^ x^ but is visible to the left of 
*NL (i.c, xu). Therefore, render the Present Span, S ? (i.c. Sq), from *cl Jta, (Le„ from to jr^. 

6B) 2404 The processing of Present Span is completed (at this point), so makeS^ (Le^ S x ) into the Present 
Span, by setting: 



(EQ18) 



S ? = 5 N = 1; 
X PL c *NL 3=2 X 1L : *PR c *NR * *U' 

2 PL ■ *HL = 2 1l! *PR " 2 NR s 2 1R^ 

6C) 2406 The Current Portion, Sq, is set equal to J N by setting: 

X CL c *NL = *tL ; *CR " X NR = X 1R* 

2 CL 55 *NL = 2 1L- *CR = *NR = 2 IR^ (EQ 19) 

CF = max < 2 Ni/ W c max(2 1Lf J 1R ) = J IL ; 

Alternatively, the Current Portion, could be set to the Present Span, Sp. (rather than S N )because it has 

the same values. However, this alternate way is not desirable for hardware implementation because this 

step and the previous step could not be done in paralleL 
6D) 2408 The Saved Span, 5 S , is invalidated, but at this point in this example, it was already invalid. 
6E) 2410 There is a new Current Portion. S c (ix„ S,), so a search is done for spans that could possibly 

occlude it. The Span Occluding Test query performs, in each SMCCAM Word 000: 

f -Q " f „v A (***p> a (*. L <* CR ) a (x -R >x CL ) a [(z mL <z CF ) v (2 |lR <2 CF )] 

« *. V * (»*1> A (X J|L <* IR ) A iX m i>X lx ) A 1{2^<Z XI ) V U ((R <I 1L )1 

This query creates the set of all Potentially Occluding Spans for the Current Portion, S c (Le^ 5, ). The 
query finds 5 0 and $2 through 5 H . 
6F) 2412 and 2414 Because Fq is not empty, there must be spans that possibly occlude the Current 
Portion. S c (Le., 5,). Therefore, the first span in Fq is read and made the New Span, 5 N . This read 
operation sets the following values: 

£ N = read(/i) » 0; 

*HL = rcad ( x L> = X 0L' X NR " "«K*R> * * 0 Ri 

2 SL « read(2 L ) - i 0L ; i NR = read(z R ) = z 0R ; (EQ21) 
</ N = read (J) = d Q ; * N s read(0 = i 0 ; 

Reading the first span in Fq yields ^o. the first span in the set The read process also deletes S 0 from Fq 
by setting (Foq = o). 

7) 2109, 2106. 2110, and 2112 The right edge of the display screen has not been reached (i^Xql < O and both 

the Present Span, 5 P (Le^ S x l and the New Spaa, 5 U (Le^S 0 X are valid. Therefore, the Span Interaction 
Parameters for these two spans are computed, and are found to be: (Far, Non, Far, Non). 

8) 21 14 The Span Interaction Type is determined from the Span Interaction Parameters, and turns out to be Type 23. 

9) 21 16, 21 18, and 2500 Because the Span Interaction Type is Type 23, Rule 4 is invoked to process ^: 

9 A) 2502 The Current Portion, S c (Le, S{U and the New Span, S N (Le*. S©X interact to cause S c to transition 
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from being viable to being hidden somewhere along its length: at point of intersection between 
S c (Le, S x ) andS N (ix^ The intersection is computed, and found to be at (*,, z{) 2702, as ihown in 

Figure 27. 

9B) 2504TlieCun ra tPojtioii,^ 

point. The right endpoint of 5 C is mnHifi»H by setting 

X CR c 

2 CR ° *v (EQ 22) 

CF = «n*X(*cL.*i) ° Z CL e Z 1L ; 

The Present Span, 5 P is still equal to all of 5^ 
9Q 2506 Hie New Span, S N (Le. 5^ is saved as the Saved Span, S s . This is done because 5 S will be 
needed later if S P fuc, 5, ) is rendered to xj. 



5 s = 5 n e °J 
*SL = *NL = *0L : *SR = *NR = *0R 

4 SR 55 *NR B 2 0R ; 



9D) 



The portion of the Saved Span, S s , to the right x, abuts S c at the x coordinate x,. If , later in the method, 
S c is rendered to x b then S s will become the Present Span,5p> 

2508 The Qnrent Portion, S c (i^ ^ rxom x a to x^ has been changed, so a search is done for spans 
that could possibly occlude it Tne Span Occluding Test query perform* in each SMCCAM Word 900: 

F «Q * f .V^,QA (**S p ) A (X^<X n ) A U JlR >X CL ) A [(2 jtL <2 CF ) V U -R <l cp )] 

'.Q - f .v^ -Q A (»*1) a (x j|L <x 1 ) a (x -R >x a ) a l(z^<2 lL ) v (r.^^)] 

TTiis query creates the set of all Potentially Occluding Spans for the Current Portion,S c (Le., S l between 
x 1L andxj). The quay finds only S 2 . The conjunction performed by the query includes F Q to prevent any 
previously read (and discarded) Potentially Occluding Span of 5, from being re-included into F Q and 
needlessly reprocessed. 

A variation of this method could skip this step and continue reading from the existing F Q rather than 
doing a query to eliminate spans from Fq. Ihis variation saves execution time by eliininating the query, 
but possibly increases execution time by failing to reduce the number of spans wFq. 
2510 and 2512 Because F Q is not empty, there must be spans that possibly occlude the Current 
Portion, S c (Le^ S x from x 1L to x,). Therefore, the first span in F Q is read and made the New Span, S s . 
This read operation sets the following values: 

S N « read(n) = 2; 
x NL = read(x L ) « x^; * NR = rcad(x R ) « x^; 

*nl - "**(*D ° inr - ^U R ) - m7S) 

</ N = read (J) = d 2 ; i N = read(j) e 

Reading the first span in Fq yields.^ the first (and only) span in the set The read process also dektesS 2 
fro m Fq by setting (Fjq = o), making Fq empty. 
10) 2109, 2106. 2110, and 2112 The right edge of the display screen has not been reached (Le..x CL <x mia ) and both 
the Present Span, S ? (Lc.S t \ and the New Span, 5 N Ce-^. are valid. Therefore, the Span Interaction 



9E) 
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Parametcrs for these two spans are computed, and arc found to be: (Far, Non, Non, Near), 

11) «14T1ie Span Interact™ Type bde^^ 

12) 2116 and 2400 Because the Span Interaction Type is Type 13, Rule 3 is invoked to continue processing^: 

12A) 2402 Tht Current Portion, S c (Le„ S x between x^tndxfrk hidden starting at ^ fix, but is 
visible to the left of XsL fix, *a> Therefore, render the Present Span, S ? (Le, S x ), from ^ to ^ 
(Le„ from x^ to x^). 

12B) 2404 Tfce processing of Present Span is completed (at this point), so makeS N (Lcty into the Present 
Span, by setting: 

S p = S u = 2; 

*PL ° *NL = *2L. * P R « * N R = x 2l* 

Z PL = *NL « 2 2lJ *PR - * N R c J 2Ri ^ ^ 

12C) 2406 The Current Portion, So is set equal to S N by setting: 

*CL = *NL = *2L : *CR = *NR * X 2R» 

*CL = 2 NL * 2 2L- *CR *= 2 NR = hi* (EQ27) 

CF = ma *(*NL' W = «»«(i2L^2R) = 2 2I/ 

12D) 2408 The Saved Span, S s . is invalidated. In Step 9C, the values forS s were set to those of S k . but these 
are now labelled invalid. 

5 S = invalid; (EQ28) 

12E) 2410 There is a new Current Portion. S c (Le„ so a search is done for spans that could possibly 
occlude it The Span Occluding Test query performs, in each SMCCAM Word 000: 

F *Q m F *V* <"* V * ( Jf l .L <Jf CR) A <*.R>*CL> A • (*«L<*CF> V < 2 .R<*CF>) 

This query creates the set of all Potentially Occluding Spans for the Current Portion, S c (Le., 5^ The 
query finds 5 3 , and 5 4 . 

2412 and 2414 Because Fq is not empty, there must be spans that possibly occlude the Current 
Portion, 5 C (Lc, Therefore, the first span in Fq is read and made the New Span, S N . This read 
operation sets the following values: 



12F) 



S N - read(n) e 0; 
x SL o read(x L ) « * 0L ; jc nr = read(* R ) - x 0R ; 
*NL c ™ d (*L) " 2 0L- *NR B "»<*(*R> - 'oR^ 

</ N = read(rf) = <* 0 ; ^ = read(i) = i 0 ; 

Reading the first span in Fq yields 5©, the first span in the seL The read process also deletes S Q from Fq 
by setting (Foq = 0). 

13) 2109, 2106. 2110, and 2112 The right edge of the display screen has not been reached (ijt*x CL <x Bmx ) and both 

the Present Span, S P (Lc, S£ and the New Span, S N (LcSq), are valid. Therefore, the Span Interaction 
Parameters for these two spans are computed, and are found to be: (Non, Non, Par, Far). 

14) 21 1 4 The Span Interaction Type is determined from the Span Interaction Parameters, and turns out to be Type 32. 
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15) 21 1 6, 21 18, and 2600 Because the Span Interaction Type is Type 32, Rule 5 is invoked to processS 2 . 

15A) 2602 and 2604 The New Span. S# (U, is bidden within the x axis projection of S c fix, S£. 
Tr*erefbre,S N (U-. $<>) is discarded Because Fq is not empty, there must be other spans that possibly 
occlude the Current Portion, S c (Lc, Sj). Therefore, the first span in F Q is read and made the New Spaa 
Sfj. This read operation sets the following values: 

5 N b read(n) e 3; 
X NL B ^(^l) = *3l/. %r = «ad(x R ) = 

'NL = read (x^ = * 3L ; ^ D «ad (z R ) = x 3R ; ^ 31) 

<* N «= read(rf) = <f* 3 ; ^ o read(0 i 3 ; 

Reading the first span in F Q yields S> the first span in the set The read process also deletes S 3 from F Q 
by setting fog - o).5 2 is still the Present Span, 5 P The status of the Saved Span, S s , is kft unchanged, 
thereby remaining invalid. 

16) 2109, 2106, 2110, and 2112 The right edge of the display screen has not been reached (i.c*cL<-W and both 

the Present Span, S ? (le.. 5^ and the New Span, S s (Lc^S 2 \ are valid. Therefore, the Span Interaction 
Parameters for these two spans are computed, and are found to be: (Far, Non, Non, Near). 

17) 21 14 The Span Interaction Type is determined from the Span Interaction Parameters, and turns out to be Type 13. 

18) 2116 and 2400 Because the Span Interaction Type is Type 13. Rule 3 is invoked to continue processing^. 

ISA) 2402 H*e Current Portion, 5 C fix. is hidden starting at x^ (Lc, jr^. but is visible to the left of 
*NL(^*3i> Therefore, renders 

2404The processing of Present Span is completed, so make the New Span,S N (Le., Sj). into the Present 
Span, Sfs by setting: 

X PL C *NL * *3I/ Z PR B *NR * ^ 

*PL E 2 NL = *3lJ 'PR » *NR « *3R* ^ ^ 

<*P " *N ° rf 3 ; «p ■ 'n e V 

1 8C) 2406 The Current Portion, S& is set equal to S N fix. Sj) by setting: 

*CL c *NL ° *3L ; *CR " *NR = *3R^ 

2 CL = 2 NL = 2 3L' a CR * *NR e Z 3R= (EQ33) 

CF ° mtX < 2 NL'W - m **(*3L'*3R> = his 

1 8D) 2408 The Saved Span, S s , is invalidated, but it was already labelled invalid in a previous step. 

S s = invalid; (EQ34) 

18E) 2410 There is a new Current Portion, S c (Le„ S 3 \ so a search is done for spans that could possibly 
occlude it. The Span Occluding Test query performs, in each SMCCAM Word 900: 

^■Q = f „V* <»* V A U aL <* CR ) A U JlR >X CL ) A [( 2>L <Z cp ) V (2 J|R <X cp )] 
F -Q * A («*3) A (0f J|L <X 3R ) A (*„ R >* 31 ) A [ (l^*^) V (l -R <l 3L ) J 



18B) 



This query creates the set of all Potentially Occluding Spans for the Current Portion, J c (Lc.Sj). The 
query finds only So* 

18F) 2412 and 2414 Because Fq is not empty, there must be spans that possibly occlude the Current 
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Portion, S c fiA, Sj). Therefore, the first span in Fq is read and made the New Span, 5 N . This read 
operation sets the following values: 

S H «= read(n) « 0; 

</ N = read(rf) « rf 0 ; / N « read(Q = i 0 ; 

Reatog trie first span in F Q yields 

from Fq by setting (Fqq » 0). The read process leaves set Fq empty. 

19) 21 09, 2106. 2110, and 2112 The right edge of the display screen has not been reached Qa^cl < x^) and both 

the Present Span, 5 P (L*. S 3 X and the New Span, 5 N (l^5 0 ), are valid. Therefore, the Span Interaction 
Parameters for these two spans are computed, and are found to be: (Non, Non, Far, Far). 

20) 21 1 4 The Span Interaction Type is determined from the Span Interaction Parameters, and turns out to be Type 32. 

21) 21 16, 21 18 F and 2600 Because the Span Interaction Type is Type 32, Rule 5 is invoked to processS 3 . 

21 A) 2602 and 2606 The New Span, S u (U„ is hidden within the x axis projection of S c (i.c, S 3 ). 
Therefore, 5 N (i.c, 5 0 ) is discarded. Because Fq is empty, there must be no other spans that possibly 
occlude the Current Portion, S c (i^, J 3 ). Therefore, the New Span, 5 N . is labelled as invalid. 

5 N * invalid; (EQ37) 

A read operation is not done. S 3 is still the Present Span, 5 P The status of the Saved Span, 5 S , is left 
unchanged, thereby remaining invalid. 

22) 2109, 2106, 2110, and 2300 Because the right edge of the display screen has not been reached (i.e..jr CL < x^) 

and also because 5 P is valid and 5 N is not valid. Rule 2 is invoked to continue processing 5 3 . 

22A) 2302 The Current Portion, S c (Le„ 5 3 X must be completely visible. Therefore, render the Present Span. 

S ? (U., 5 3 ), from Xa. toJE C* (Le^ from x^ to xg). 
22B) 2304 and 2306 Because the Saved Span. S s , b not valid, there was not an intersecting span that 

reduced the size of 5 C . Therefore, a query is done to look for an Abutting Span. The query performs, in 

each SMCCAM Word 900: 

^•Q - ^.v a (*„ L = * CR ) a (2 mL «= x CR ) 

'.Q * A <*. L = * 3R ) A (I* -*,,) (EQ38) 

This query creates the set of aU Abutting Spans for the Current Portion, 5 C (Lc, 5 3 ) and stores them in 
Fq. The query finds only 5 7 . 
22C) 2308 and 2310 Because F Q is not empty, there must be an Abutting Span. Therefore, the first span in 
Fq is read and made the Present Span, S P This read operation sets the following values: 
Sp e read(n) = 7; 
x pL = read(* L ) « x pR « read(* R ) = x^; 

z PL - read(i L ) = hl i 2pR * read(2 R ) = j^; 
dp » read(</) = < p = read(0 = i ? ; 

Reading the first span in Fq yields S 7 , the first (and only) span in the set The read process also deletesS 7 
from Fq by setting (Fjq « o). The read process leaves set Fq empty. 
22D) 231 2 The Current Portion, is set equal to 5 P (Le^ S7) by setting: 
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X CL E *PL = *7L ; *CR ° X PR = *7R* 

*CL - 2 FL m *7lJ *CR " *PR " h*' CEQ40) 

cf = D "( ; PL'W ° »"(*7L»*7r) = 2 7R ; 



10 



This step can be done concurrently with Step22C 
22E) 2314 There is a new Current Portion, 5 C (Le^ 5aX so a search is done for spans that could possibly 
occlude it The Span Occluding Test query performs, in each SMCCAM Word 900: 

F *Q s F .V A (** S p) A ( X »L <, CR> A ^ X mBL >X cO A I (*«L <2 CF> V ^ 2 »K <2 CF^ 

(EQ41) 

F «Q = f »V A t 71 * 7 ) A (*»L <X 7R> a < x »R >X U.) a K 2 «L <z 7r) V (**R <2 7r)1 



This query creates the set of all Potentially Occluding Spans lor the Current Portion, 5 C (i.e., 5 7 ). The 
query does not find any spans, so Fq is empty. 
22F) 231 6 and 231 8 Because Fq is empty, there must be no spans that possibly occlude the Current Portion. 
5c (lc. £7). Therefore, the New Span, 5 N , is labelled as invalid. 
15 5 N = invalid; (EQ42) 

A read operation is not done.S 7 is still the Present Span,5p 
23) 2109, 2106, 2110, and 2300 Because the right edge of the display screen has not been reached (Lcjcq, < x^) 
and also because Sp is valid and S# is not valid. Rule 2 is invoked to process 5 7 . 
20 23 A) 2302 The Current Portion, S c (Le^ 5 7 X must be completely visible. Therefore, render the Present Span, 

S P fix^ S 7 ), from *<x tox at 0*- from to x^). 
23B) 2304 and 2306 Because the Saved Span, 5$, is not valid, there was not an intersecting span that 
reduced the size of Sc- Therefore, a query is done to look for an Abutting Span. The query performs, in 
each SMCCAM Word 000: 

F *Q s F -V A <*.L m *CR> A < Z *L " 2 CR> 

(EQ43) 

F nQ b F mV A <*.L m *7R> a (l »L ° 2 7R> 



25 



This query creates the set of all Abutting Spans for the Current Portion, S c (Le., S-j) and stores them in 
Fq. The query does not find any spans, sofq is empty. 
30 23C) 2308 and 2320 Because Fq is empty, there is not an Abutting Span. All spans completely to the left of 

xqi (lc.xth) must be hidden, so they are declared invalid. This is done by a query that performs, in 
each SMCCAM Word 800: 

F mV " F mV A t **R > X C*) M M 

(EQ44) 

35 

This query reduces the number of valid spans by reducing the spans in set F v from 15 to 10. At this 
point, F v consists of Sq, Sj, and S g through S u . 
23D) 2322 There is neither a valid Present Span, Sp nor a valid New Span, 5 N . Hence, both are labelled as 
invalid. 

40 S p = invalid; 

S N « invalid; 

23E) 2324 The Current Portion, S c , is set equal to: 
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X CL e *CR = *7Ri X CR = 

*CL e iafini^: *cr c iDVAlid » (EQ46) 
2^ = infinity; 

5 24) 21 09, 21 06, 2108, and 2200 Because the right edge of the display screen has not been reached (Le., < ^) 

and also because the Present Span, £p is not valid and Fy is not empty (indicating that at least some spans are 
valid). Rule 1 is invoked. Here, Rule 1 is used to search for the frontmost span aU^. When found, this frontmost 
span is processed as the fresent Span, Sp. 

24A) 2202 Do a query to find all valid spans that could affect the current raster line at (Le_, x^). The 
10 query performs, in each SMCCAM Woid 900: 

r c r A /v <• \ CEQ47) 

t mQ C *iiV a < X »L Sjf 7R> 

This query finds Sq, 5j, 5 6 , and 5 8 . The query operation could include i coordinate comparisons that 
15 check for values less than Zcp. which has been set to infinity. 

24B) 2204 and 2222 Because Fq is not empty, there must be at least one span that could affect the current 
raster line atx^ (ix„ 0^). Therefore, the first span in Fq is read and made the New Span,S N . This read 
operation sets the following values: 
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S N s read(n) = 0; 
x NL = read(x L ) = x^; ^ « read(* R ) * * 0R ; 
*NL B «ad(z L ) * 2 0L ; j NR s read(x R ) «= z 0R ; 
J N = read(rf) e rf 0 ; j n = read(i) = i 0 ; 

Reading (he first span yields the leftmost span in Fq. which is The read process also deletes S 0 from 
25 Fq by setting (Fqq - O). 

24C) 2224 The i value for the New Span, 5 S (Le n So), at the x coordinate xq. 0-*-. *7r) is computed as z^p. 

'temp = *NL* <*CL-*NL)*N g *0L + <*7R-*aL>*0 (EQ49) 



30 



40 



The position (jp^, z %eap ) 2704 is shown in Figure 27. 
24D) 2226, 2228, and 2232 The computed value, is less than Zq. (lc infinity X so make the New 
Span, S N (Le„ So), into the Present Span, by setting: 

S ? = S N e 0; 

*PL = X NL = *0L : *PR = X NR = *0R : 

(EQ50) 

*PL = *NL c *0L ; *PR = *NR * 2 0R ; 

d ? m d H * J 0i *P c 'N = V 

24E) 2236 The Current Portion, 5 0 is set to the portion of the Present Span, 5 P (ix„S 0 ) to the right of 
*CL *7R) by setting: 

*CR c *NR ° X 0R ; 

2 CL e2 l«np» *CR = 2 NR = ^ (EQ51) 



24 F) 2237 and 2238 As stated above, the objective of this part of the method is to find the frontmost span at 
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^(Lc^xtr). At j^lClcxtr), the 2 coordinate of the Present Span, Sp (Le^ 5qX is equal to 2^. 
Therefore, any span in front of Sp (Le., 5 0 ) at Xq^ (Le,, most be at least partially located closer to the 
observer than z- ^j .. The set Fq is not empty and includes all the c flI v*i'1ntf«F for frontmost span at 
^(Le^xTj^and some of these candidates maybe eliminated with the query: 

F „Q ' F .V*F^ I(^<* ump ) V ( IliR < 2ump )J V* 5 * 

This query operation keeps candidate spans that have either endpoint 2 coordinate less than After 
the query, F Q contains only 5 g . 

A variation of this method could slop this query to save time, but does not delete spans hidden by 
S F (i.c S 0 ) at (Le., xj^), and so must read all the spans that could affect the current raster line at 
*CL *7r)- # A* depth complexity is small then this variation would yield a net savings. However, 
for large depth complexity, the time saved by eliminating candidate spans would outweigh the time spent 
doing the query operations. Hence, the method choice depends on the expected depth complexity of the 
scene. 

To avoid making an a priori assumption about scene complexity, the SMCCAM800 could include a 
mechanism for deierrnining the depth complexity atx^ by counting the number of spans in the set F Q . 
If the number of spans in Fq is small, the query operation of this step is skipped, and each span inF Q is 
read. If the number of spans in Fq is sufficiently large, the query operation is not skipped, and some 
spans in Fq are drifted, and a net saving is achieved. 
24C) 2204 and 2222 Because Fq is not empty, there must be at least one more candidate span that could be 
frontmost atXcL (Le^^). Therefore, the first span in Fq is read and made the New Span, 5 N . This read 
operation sets the following values: 

5 N s read(n) «= 8; 

2 NL * read(2 L ) * x IL ; = read(z R ) = 2 gR ; 

d u « read (^) = </ f ; i' N o read(i) = i,; 

Reading the first span yields the only span in Fq, 5 8 . The read process also deletes 5 8 from Fq by setting 
(FgQ = 0). The read process leaves set Fq empty. 

2224 The rvalue for the New Span,S N (Lc^S& at the x coordinate x^ (Le„ x^) is computed as 2^. 



24H) 



The position (^tr. 2^) 2704 is shown in Figure 27. 
241) 2226, 2228, and 2232 The computed value, 2^ is less than 2ql (i.e. z coordinate of S 0 at 

computed as i Ump in Step24Q, so make the New Span. S s (Le-, into the Present Span. 5 P by 
setting: 

Sp = S w » 8; 

*PL = *NL ° *IL ; X PR = *NR = *|Ri 

2 PL ~~ *NL 2 IL* *PR e 2 NR 0 Z SR» 



24J) 2236 The Current Portion, S c . is set to the portion of the Present Span, Sp (i-e^Sg) to the right of 
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*CL (Lc^x 7R )by setting: 

*CR = *NR = *SR ; 

2 CL B 2 t«np ; 2 CR = X NR = 2 IR» (EQ56) 

2 CF e n «(WW = maX ( Z lemp' I IR) = 'sr! 

24K) 2237, 2204, 2206, and 2214Because F Q is empty and S P (Lc^ 5g) is valid, a search is done for spans 
that could possibly occlude the Current Portion, S 0 (Lc^Sgtotbe right of The Span Occluding 
Test query performs, in each SMCCAM Word 000: 

F nQ " F »V * <»* V A (X -L <X CR ) A (X J|R >X (X ) A [ U JtL <X cp ) V 

f «Q - ^V* <»*8) A (X jtL <X JR ) A (X -R >X ?R ) A [(2 -L <2 gR ) V (2„ R <2 |R )] ^ 5?> 

This query creates the set of all Potentially Occluding Spans for the Current Poition.S c (i.e., S z to the 
right o[x m y The query finds S 0 and 5$. 
24L) 221 6 and 221 8 Because F Q is not empty, there must spans that possibly occlude the Current Portion, 
S c (i-e- 5g to the right of*™). Therefore, the first span in F Q is read and made the New Span, 5 N . This 
read operation sets the following values: 

5 N «= read(fi) ■= 0; 
x NL = read(jr L ) «= * 0L ; ^ R = reed(x R ) = jr 0R ; 

d H m read(<f) = d Q ; ^ e read(i) e i 0 ; 

Reading the first span in Fq yields the first span in the seL The read process also deletes 5 0 from F Q 
by setting (FqqeO). 

25) 2109, 2106, 2110, and 2112 The right edge of the display screen has not been reached (Le^ < a^) and both 

the Present Span, 5 P (Le.. Sg). and the New Span. S N (lc^q). are valid. Therefore, the Span Interaction 
Parameters for these two spans are computed, and are found to be: (Nan, Non, Far, Near). 

26) 21 1 4 The Span Interaction Type is determined from the Span Interaction Parameters, and turns out to be Type 31. 

27) 21 1 6, 21 18, and 2500 Because the Span Interaction Type is Type 31. Rule 4 invoked to processS 8 : 

27 A) 2502 The Current Portion, S c (ix„ S 8 to the right of x^X and the New Span. 5 N <Le„ S£. interact to 
cause S c to transition from being visible to being bidden somewhere along its length: at point of 
intersection between S c (Le, 5 8 to the right of and S N (L^ So). The intersection is computed, and 
found to be at (xj, z 2 ) 2708, as shown in Figure 27. 

27B) 2504 The Current Portion, S c (ix, 5 8 to the right of is shortened by changing its right end point to 
the intersection point The right endpoint of S c is modified by setting 

X CR = *v 

X CR e V (EQ59) 
: CF « max(2 CL ,r,) = z x ; 

The Current Portion, S c is now the portion of S B between andxj. The Present Span, S p is still equal 
to all of S 8 . 

27C) 2506 The New Span, S N (i.e^ is saved as the Saved Span, S s . This is done because S s will be 
needed later if Sp (i-e., S 8 ) is rendered to*]. 
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s s * s n ~ ° > 

X SL ° *NL = x 0lJ *SR c *NR = *0R : 

hL e *NL e ^OLi *R = *NR = 2 0R : ^ 6(9 

rf s = rf N = </ 0 ; i s « i N = j 0 ; 

The portion of the Saved Span, S s , to the right Xj abuts S c at the x coordinate Xj. If, later in the method, 
S c is rendered Id x h then S s will become the Present Span, Sp. 
27D) 2508 The Current Portion, S c (Le^ S B bom to Xj) has been changed, so a aearch is done for spans 
that could possibly occlude it The Span Occluding Test query performs, in each SMCCAM Word 900: 

»Q = F *y AF nQ* <"* S P> A ( X aL<*CR> * <*.R>*CL> A [<*,L<*CF> V <*.R<*Cf)] 

F *Q - f .v^ aQ a (n#8) a <x A <* f ) a (* -R >x JE ) A|(, -L <; 1 ) v U^-c*,)] (EQ61) 

This query creates the set of al) Potentially Occluding Spans for the Current Portion, S c (Le., 5 8 from 
*7R 10 The query does not find any spans; therefore, Fq is empty. 
27E) 2510 and 2514 Because Fq is empty, there must not be any spans that possibly occlude the Current 
Portion, 5 C (ix., 5 g from x^ to Xj). Therefore, the New Span, S N . is declared invalid. 

5 N = invalid; (EQ62) 

28) 2109, 2106, 2110, and 2300 Because the right edge of the display screen has not been reached (Lcxo. < W ) 
and also because S P is valid and 5 N is not valid. Rule 2 is invoked to process 5 8 . 

28 A) 2302 The Current Portion. S c (Le, S B from x^ to z,). must be completely visible. Therefore, render the 

Present Span, 5 P (Le., SgX from j^l to *cr (»•*•• trom x^ to xfr 
28B) 2304 and 2326 Because the Saved Span, J s , is valid, there was an intersecting span that reduced the 

size of 5 C . Therefore, the Saved Span, S s (Le, So), is made into the Present Span, by setting: 

S p = 5 S e 0; 

*PL * *SL = *0L ; *PR B *SR - 'OR! 

2 PL " 2 SL - *0L» *PR 65 *SR * 2 0R' 

*p * *s ° rf o- 'V - 's c V 

28C) 2328 The Current Portion, Sq, is set to the portion of Sp (Le^ 5 0 ) that is to the right of x h That way, the 
Saved Span, S s (Le, 5qX acts the same as an Abutting Span for the portion of J 8 to the left of x It where 
the abutting takes place atX|. This is done by setting: 

X CL c *CR = *V *CR = *SR = X 0R ; 

Z CL S2 CR =2 I ; *CR " *SR e 2 0R*> (EQ64) 

: CF = max(2 CRf 2 SR ) = max(2,,2 0R ) = zf 

This step can be done concurrently with Step 28 B. 
28D) 2330 Because the values for the Saved Span, 5 S , have been transferred to the Present Span, S h S s is 
invalidated. 

S s « invalid; (EQ65) 



28E) 231 4 There is a new Current Portion, S c (Lc, S 0 to the right of x x X so a search is done for spans that 
could possibly occlude it The Span Occluding Test query performs, in each SMCCAM Word 900: 
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F *Q ° f »V A A (X -L <X CR ) A (x -R >Jf CL ) A [(X -L <2 cp ) V (2 JiR <Z cp )] 

This query creates the set of all PotentiaUy Occluding Spans for the Current Portion, 5 C (Le„ S Q to the 
right of xj). The query finds S 8 through 5 U . 
28F) 2316 and 2332 Because Fq is not empty, there must spans mat possibly occlude the Current Portion, 
5c (Le- 5 0 to the right of X|). Therefore, the first span in Fq is read and made the New Span, 5 N . This 
read operation sets the following values: 

5 N = read(n) « 8; 
*HL = = * tL S *NR e reiul <*R> ° *sr: 

*NL m re * d (* L ) = Z NR ° rc * d < 2 R) B *s R ; (HQ 67) 

rf N = read ((f) = rf,; f N = read(i) = i g ; 

Reading the first span in F Q yields S 8 . the first span in the seLThe read process also deletes S 8 from F Q 
15 by sewing (fgq = o). 

An alternate method could include a way to prevent the left side partner of an intersecting span pair from 
being considered as a Potentially Occluding Span of the right side partner. This could be done with an 
additional query of an SMCCAM800 that can do two simultaneous inequality tests on n in each 
SMCCAM Word 900. 

29) 2109, 2106, 21 10, and 211 2 The right edge of the display screen has not been reached (Lcx^ < i^) and both 
the Present Span, S ? (Le., and the New Span, 5 N (Le.,5gX are valid. Therefore, the Span Interaction 
Parameters for these two spans are computed, and are found to be: (Non, Near, Equal, Non). 

30) 21 14 The Span Interaction Type is determined from the Span Interaction Parameters, and turns out to be Type 21. 

31) 21 16, 21 18, and 2600 Because the Span Interaction Type is Type 21. Rule 5 is invoiced to processSo- 
25 31 A) 2602 and 2604 The New Span,S N fix,, 5g). is hidden within the x axis projection of S c (ix., S 0 to the 

right of X|). Therefore, S N (Le.. Sg) is discarded. Because Fq is not empty, there must be other spans that 
possibly occlude the Current Portion, S c (Le*, S 0 to the right of Xj). Therefore, the first span in F Q is read 
and made the New Span, 5 N . This read operation sets the following values: 

5 N e read(n) « 9; 
x NL = read(x L ) « x 9L ; x NR = read(x R ) = x 9R ; 
r NL = read(x L ) = * 9L ; 2 hr 15 "*d<2 R ) - *9r» 
</ N = read(rf) = d 9 ; < N = read(i) = # 9 ; 

Reading the first span in Fq yields 5$, the first span in the set The read process also deletes S 9 from Fq 
35 by setting (F^ = o). 5 0 is still the Present Span,5p The status of the Saved Span,5 5 , is left unchanged, 

thereby remaining invalid. 

i 32) 2109, 2106. 21 10, and 2112 The right edge of the display screen has not been reached (ix^Xo. < x^) and both 

the Present Span, S P (Lc, S 0 \ and the New Span, S s (it^S 9 \ are valid. Therefore, the Span Interaction 
Parameters for these two spans are computed, and are found to be: (Far, Far, Non, Non). 
40 33) 21 14 The Span Interaction Type is determined from the Span Interaction Parameters, and turns out to be Type 5. 

34) 21 1 6 and 2400 Because the Span Interaction Type is Type 5, Rule 3 is invoked to continue processing 5^ 

34 A) 2402 The Current Portion, 5 C (Lc, S 0 to the right of Xi), is hidden starting at x^ (Le-, xg^ but is visible 
to the left of Xkl (i*- Therefore, render the Present Span, 5 P (Le^ S 0 \ from xq. to x^i (Le., from 
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34B) 2404 The processing of Present Span is completed (far now), so nuke the New Span^ (Le„ $3), into 
the Present Span, 5p by setting: 

5 P = 5 N = 9; 

*PL ° *NL = Hi* *PR = *NR ° *9R» 

J PL X NL ~ 2 9L' 2 PR - *NR = 2 9R» 

34C) 2406 The Current Portion, Sq, is set equal to 5 N (ix., 5 9 ) by setting: 
X CL = ^ C *9L ; *CR = *NR = *9R ; 

Z CL * *NL " 2 9lJ 2 CR e Z NR = 2 9R ; (EQ70) 

CF = max ( 2 NL'W = msx(i3 L ,2 3R ) = z 9L ; 

34D) 2408 The Saved Span, 5 S , is invalidated, but it was already labelled invalid. 

S s «= invalid; (EQ71) 




A read operation is not done. S 9 is still the Present Span, 5p The status of the Saved Span, 5 S . is left 
unchanged, thereby remaining invalid. 
35) 2109, 2106, 2110, and 2300 Because the right edge of the display screen has not been reached (U^x^ < x^) 
and also because S ? is valid and 5 N is not valid. Rule 2 is invoked to process 5$. 

35A) 2302 The Current Portion, S c (Le„ S 9 \ must be completely visible. Therefore, render the Present Span. 

5p (Le„ 5 9 ), from to (Le^ from jcjl to x^). 
35B) 2304 and 2306 Because the Saved Span, S s , is not valid, there was not an intersecting span that 

reduced the size of 5 C . Therefore, a query is done to look for an Abutting Span. The query performs, in 

each SMCCAM Word 900: 

F .Q = F -V * ° *9R> A (*«L * W ?4) 

Ibis query creates the set of all Abutting Spans for the Current Portion, Sc (Le., S3) and stores them in 
Fq. The query finds only S n . 
35C) 2308 and 2310 Because Fq is not empty, there must be an Abutting Span. Tberefore, the first span in 
Fq is read and made the Present Span,5p This read operation sets the following values: 
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S p c read(n) o 11; 
XpL = readf^) *= * UL ; * pR = read(x R ) = * UR ; 
z pL = read^) « * nL ; ZpR = read(i R ) = i nR ; 
<f p e read(</) s rf u ; / p c read(i) = i u ; 



(EQ75) 



Reading the first span in Fq yields $n, the first (and only) span m the set The read pnx^ also de^ 
Six from Fq by setting (f U q «= o). The read process leaves set Fq empty. 
35D) 231 2 The Current Portion, 5 0 b set equal to S P (Le^ ^ , ) by setting: 

*CL " *pl c *cr * *pr s *n*: 

2 CL a *PL = 2 llO *CR = *PR c 2 1\*S (EQ76) 

CP = max (*I»L'*llR> = max (*UL'W e 2 UR- 

35E) 2314 There is a new Current Portion, S c (i.e^5 n X so a search is done for spans that could possibly 
occlude iL The Span Occluding Test query performs* in each SMCCAM Word 900: 

f ,Q = ^v* <»*H> a (^l<*iir) * <*„r>*ul> A l(r. L <i UR ) v <*.r< W) 

This query creates the set of all Potentially Occluding Spans for the Current Portion, S c (Le., 5 7 ). The 
query finds only Sq. 

35F) 2316 and 2432 Because F Q is not empty, there must be spans that possibly occlude the Current 
Portion, S c (ix., S u ). Therefore, the first span in F Q is read and made the New Span. 5 N . This read 
operation sets the following values: 

S s & read(n) = 0; 
*NL 88 "* d (* L ) ° X 0L* *NR " rewl <*R> = * 0 R ; 

(BO 78) 

2 HL » ««*(«L> = 'oi^ *NR " = Z 0 R^ 

</ N - read (4) = d Q ; i N - read(i) = i 0 ; 

Reading the first span in Fq yields the first (and only) span in the set The read process also deletes S 0 
from Fq by setting (Fqq = o). The read process leaves setFQ empty. 

36) 21 09, 21 06. 21 1 0, and 21 1 2 The right edge of the display screen has not been reached (Lcjccl < *** both 

the Present Span, 5 P (Le.,S„), and the New Span, S N (i-e^So), are validL Therefore, the Span Interaction 
Parameters for these two spans are computed, and are found to be: (Non, Non, Far. Far). 

37) 2114 The Span Interaction Type is determined from the Span Interaction Parameters, and turns out to be Type 32. 

38) 21 16, 21 18, and 2600 Because the Span Interaction "type is Type 32, Rule 5 is invoked to process^,. 

38A) 2602 and 2606 The New Span, S N (i.e., S 0 \ is hidden within the x axis projection of S c (Le., 5 U ). 
Therefore, 5 K (Le., S 0 ) is disca r de d . Because Fq is empty, there must be no other spans that possibly 
occlude the Current Portion, S c (ix., S n \ Therefore, the New Span, S N , is labelled as invalid. 

S N = invalid; (EQ79) 

A read operation is not done. S$ is still the Present Span, The status of the Saved Span, £ s , is left 
unchanged, thereby remaining invalid. 

39) 21 09, 21 06, 21 1 0, and 2300 Because the right edge of the display screen has not been reached (Le,. jccl < x^) 

and also because Sp is valid and 5 N is not valid. Rule 2 is invoiced to continue processing Su. 



39B) 
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39A) 2302 The Current Portion, S c (Le„ S n ), must be completely visible. Therefore, render the Promt Span. 
Sp (Le, S n ), from x^ to (Le, from x 11L to ;r 11R ). 

2304 and 2306 Because the Stved Span, S§, is not valid, there was not an intersecting span that 
reduced the size of Therefore, . query i, done to look for an Al^ Span. Tta query perftmns, in 
each SMCCAM Word 800: 

'"-Q = F m\ a {x^ = a (i^ «= z CB ) 

This query creates the set of all Abutting Spans for the Current Portion. J c (le. 5„) and .tores them in 
Fq. The query does not find any spans, so Fq is empty. 
39C) 2308 and 2320 Because F Q is empty, there is not an Abutting Spar, All spans completely to the left of 
JfcR (it., x nv ) must be hidden, to they are declared invalid. This is done by a query that performs, in 
each SMCCAM Word 900: 

f .v ef .v A Kn>i C ii) 

f .v=F.vMi R >r, 1R ) CEQ81) 

This query reduces the number of valid .pans by reducing the spans in se,F v from 10 to 5. At this point, 
fyconsists of Jo.5,. andS, 2 through S, 4 . 

39D) 2322 There is neither a valid Present Spin. * nor « valid New Spaa. S N . Hence, both are labelled as 

invalid. 

S p s invalid; 

5 N = invalid; (HQ 82) 

39E) 2324 The Current Portion, b set equal to: 

X CL s *CR s x iir» *cr " invalid; 
2 CL = infinity; * CR * invalid; 
Zqp = infinity; 

2109, 2106, 2108, and 2200 Because the right edge of the display screen has not been reached (i*^ < x^) 
and also because the Present Span.** i, not valid maF v km»tn q ^0«lk^ v ^iu1 g mt tl L va , m 
valid). Rule 1 is invoked. Here, Rule 1 i, used to «=arch for the frontmost ap» «, 11R . When found, this 
frontmost span is processed as the Present Span,5p 

40A) 2202 Do i query to find all valid spans that could affect the current raster line siz^ (La, , 11B > The 
query performs, in each SMCCAM Word 900: 

This query finds 5„, S,,and S a . The quay operation could include 2 coordinate comparisons that check 
for values less than jqj which has been set to infinity. 
40B) 22M and 2222 Because f Q is ™*emr^.tr^ 

raster line at^ <Le,x llB ). Therefore, the first span in Fq is read and made the New Span.S N . This 
read operation sets the following values: 
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S N = read(n) « 0; 
X SL ° « x^; « read(x R ) » j: or ; 

J NL e »wd(*L) * *NR " ***<K*r) = 

</ N = rcad(J) = rf 0 ; ^ = read(i) * i 0 ; 



(EQ85) 



Reading the first span yields the leftmost span in Fq, which is5<>.Tbe read process also deletes S 0 from 
Fq by setting (Fqq « o). 

40C) 2224 The z value for the New Span. S s (Le^ at the jr coordinate ^ (Lt ( x 11R ) is computed as 
2 ie«p m 2 NL + ( x CL" x NL) rf N = *0L + <*11R- *0L>4> (EQ86) 

The position (x nR , 2^) 2710 is shown in Figure 27. 
40D) 2226, 2228, and 2232 The computed value, 2^ is less than 2q. (Le„ infinityX so make the New 
Span, 5 N (Le„ into the Present Span, 5p by setting: 

5 p - S N - 0; 

*PL " *NL - *PR = *NR = *0R' 

*PL B 'NL e Z 0L5 *PR = »NR ° *0R= 

f P " 'N 



40E) 2236 The Current Portion, % is set to the portion of the Present Span, 5 P (Le^o> to the right of 
Xjx (Lc, x x , R ) by setting: 



*CR = X NR B *0R ; 

*CL * *i«n P ; *CR " *NR " Z 0R : (EQ 88) 

CF C m «<*len, P -W " W " 'temp! 

40F) 2237 and 2238 As stated above, the objective of this part of the method is to find the frontmost span at 
X CL (»•*•. *iir)- At JCfx (Lc, * 11R ), the z coordinate of the Present Span, 5 P (Lc, 5 0 X is equal to 2^. 
Therefore, any span in front ofSp (Le^ S 0 ) at jsq. (i*^ *hr) must be at least partially located closer to 
the observer than 2^. The set Fq is not empty and includes all the candidates for frontmost span at 
*a. & e » x urX tnc ^ some of these candidates maybe eliminated with the query: 

This query operation keeps candidate spans that has either endpoint 2 coordinate less than 2 tBDp . After 
the query, Fq is empty. 

40G) 2204. 2206, and 2214 Because Fq is empty, there can not be any other candidate span that could 
frontmost at j^l G*- *iir). Also, because Sp(Le^S 0 )is valid, perform, in each SMCCAM Word 800, 
the Span Occluding Test query. 

f .Q " '.V A (*** P ) A (^ L <X CR ) A (X mZ > XcL ) A [(2 jtL <2 cp ) V 
f ,Q - ^.VA (H*0) A (X |lL <X 0R ) A (X -R >X UR ) A [(2 -L <2 Ump ) V (2 -R < 2 |tnp ) ] ffQ 90) 

This query creates the set of all Potentially Occluding Spans for the Current Portion, S c (Le., S 0 to the 
right of x t jr> The query does not find any spans, and Fq is empty. 
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4GH) 2216 and 2220 Because Fq is empty, there must be no other spans that possibly occlude the Current 
Portion, S c (Le^ So to the right of x t ^ Therefore, the New S pan, S K . is labelled as invalid. 

S N = invalid; (EQ91) 

A read operation is not done.S 0 is still the Present Span,S P The status of the Saved Span, S s , is left 
unchanged, thereby remaining invalid. 
41) 2109, 21 06, 211 0, and 2300 Because the right edge of the display screen has not been reached (le.,*^ < x^) 
and also because S P is valid and S N is not valid, Rule 2 is invoked to process S^ 

41 A) 2302 The Current Portion, S c (Le^S 0 to the right of * UR ), must be completely visible. Therefore. 

render the Present Span, S P (le n So), from Jta. to ^ (i.e., from x l 1R to jc^). 
41B) 2304 and 2306 Because the Saved Span, S s , is not valid, there was not an intersecting span that 

reduced the size of S c . Therefore, a query is done to look for an Abutting Span. The query performs, in 

each SMCCAM Word 900; 

" F *V A (^L - *CR> A <*«L = Z CR> 

This query creates the set of all Abutting Spans for the Current Portion, S c (Le., So) and stores them in 
Fq. The query does not find any spans, so Fq is empty. 
41C) 2308 and 2320 Because Fq is empty, there is not an Abutting Span. All spans completely to the left of 
*OL (i-e-tXQR) must be hidden, so they are declared invalid. This is done by a query that performs, in 
each SMCCAM Word 900: 

r .v - ^V A ( Jf .R>' C R> 

'.v«'.vM*. R >* 0R ) 

This query reduces the number of valid spans by reducing the spans in setF v from 10 to 2. At this point, 
f v consists of S{ andS 14 . 

41D) 2322 There is neither a valid Present Span,S P nor a valid New Span, S N . Hence, both are labelled as 
invalid. 

Sp s invalid; 

S N « invalid; (EQW) 

4 IE) 2324 The Current Portion, S 0 is set equal to: 

*CL - *CR s *or: *cr - invalid; 
2 cl = infinit y: 2 CR « invalid; (EQ95) 
z CF = infinity; 

42) 21 09, 21 06, 21 OB, and 2200 Because the right edge of the display screen has not been reached (Le^x^ < x^) 
and also because the Present Span, Sp is not valid and F y is not empty (indicating that at least some spans are 
valid). Rule 1 is invoked. Here, Rule 1 is used to search for the frontmost span itx^. When found, this frontmost 
span is processed as the Present Span, Sp. 

42A) 2202 Do a query to find all valid spans that could affect the current raster line atx^ (Le., x^). The 
query performs, in each SMCCAM Word 900: 
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This quay finds 5 ! tod 5 14 . The quay operation could include z coordinate comparisons that check for 
values less thanz^p which has been set to infinity. 
42B) 2204 and 2222 Because is not empty, there must be at least one span that could affect the current 
raster liiieat^fix^^. Therefore, the 
operation sets the following values: 

S s «= read(n) = 1; 
*NL = rCAd <*L> = 'iL- X NR e rc4d <*R> = 

*NL " = J lLi 2 NR B "» d (* R ) = * 1R I 

d s = read (4) s / N = read(i") = 

Reading the first span yields the leftmost span in F Q , which is S t . The read process also deletes S x from 
F Q by setting fo Q =0). 

2224 The z value for the New Span, S s (Le„ 5j X at the * coordinate fix. ^r) is computed as 

2 um P c 2 NL+ <*CL-*NL> rf N C 2 iL + <*0R-*1L> d \ (EQ 98) 



42C) 



The position (xor< Xump) 2712 is shown in Figure 27. 
42D) 2226, 2228, and 2232 Tne computed value, 2^ is less than Zq. (Le. infinity), so make the New 
Span, 5 N (Le„ S,) t into the Present Span. Sp> by setting: 

5 P c 5 N = *: 

X PL = *NL = 'PR * *NR « *!»'• 

'PL * *NL = hi} *PR = *NR " ^ 

42E) 2236 The Current Portion, 5 & is set to the portion of the Present Span, S ? (ij^S x ) to the right of 
*cl (»•*•. *or) by setting: 

*cr = *nr " X 1R^ 

2 CL B 2 teop ; 2 CR = 2 NR ~ *1R*' (EQ 100) 

CF " m **( 2 temp'W ° max (*u»pF*lR> - 'unip- 

42F) 2237 and 2238 As stated above, the objective of this part of the method is to find the frontmost span at 
*CL At *fcL 0-*- *or)» the i coordinate of the Present Span, 5 P (Le^5 1 X is equal to z^. 
Therefore, any span in front of S P (Le., £]) atx^ (Le^ *o R ) must be at least partially located closer to the 
observer than 2^. The set F Q is not empty and includes all the candidates for frontmost span at 
*CL (i- e >* ^qr)* and so™ of these candidates maybe eliminated with the query: 

f .Q - f -vaF q a [U JlL < W v (2. R < W J « l0 » 

This query operation keeps candidate spans that has either endpoint 2 coordinate less than ^ After 
the query, Fq contains only 5 J4 , and did not get changed by the query. 
42G) 2204 and 2222 Because Fq is not empty, there must be at least one more candidate span that could be 
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frontmost at afcL (Lc, JtflR). Therefore, the first span in F q is made the New Sp^S^.llii read 
operation sets the following values: 

S N = read(n) = 14; 

^ = read (o^) = * 14L ; = read (x R ) = x, 4R ; ^ ^ 

*NL c "^('J = J 14L^ *NR ° » 'MR! 

<* N o read(rf) « </ |4 ; f H o read(i) - i J4 ; 

Reading the first span yields the only span in Fq, that is, 5 14 . The read process also deletes 5 ]4 fromFg 
by setting (f 14 q ■= o). The read process leaves set Fq empty. 
10 42H ) 2224 The xvah* for the New Spaix,S N ^ 

2 ump = Z NL + ^CL-^Nl)^ ° 2 14L + < X 0R ~ *ML> *14 (EQ 103) 

The position (iqr, z^) 271 4 is shown in Figure 27. 
15 42I > 2226 » 2228, and 2232 The computed value, is less than 2cL (Lc, i coordinate of S 0 at jr^. 

computed as 2^ in Step42C), so make the New Span, 5 N (Lc,S, 4 ), into the Present Span. Sp> by 
setting: 

- 5 N = 14; 
*PL c *NL = X 14L ; *PR c *NR B 'WR^ 

20 , (EQ104) 

2 PL = *NL * 2 14L ; 2 FR - 2 NR * z 14Rl 

dp a rf N o 4/ M ; | p . i N o i J4 ; 

42J) 2236 The Current Portion, 5 0 is set to the portion of the Present Span, S P (Le„S J4 ) to the right of 
*CL *or) ^ «tting: 

25 

*CR = *NR B X MR : 

2 CL m r mnp» 2 CR " 2 NR c 2 MrI (EQ 105) 

CF " nU (W 2 NR' C m * X <W W ■ 2 14RJ 

Because, as shown Figure 27, is equal to the max( ) function could choose either or Zq^. 
30 42K) 2237, 2204, 2206, and 221 4 Because F Q is empty and£ P (Le^ 5 J4 ) is valid, a search is done for spans 

that could possibly occlude the Current Portion, 5 C , G-e- S l4 to the right ofx^ The Span Occluding 
Test query performs, in each SMCCAM Word 900: 

= f *V A (»*Sp) A (*. L <* C R> A (X -R >Jf CL ) A [ (Z mL <2 CF ) V <2. R <* CF )] 



35 



F nQ " A U J ,L<* 14R ) A (X J|R >X ttmp ) A [(Z ||L <Z UR ) V (l JlR <r MR )] ^ 106 > 



This query creates the set of all Potentially Occluding Spans for the Current Fortion,5 c (Lc n S l4 to the 
right of jfa). The query does not find any spans, so Fq is empty. 
42L) 2216 and 2220 Because F Q is empty, there must be no other spans that possibly occlude the Current 
Portion, S c (Le-.Su to the right of ofo). Therefore, the New Span,S N . is labelled as invalid. 
40 *N c "valid; (EQ 107) 



A read operation is not done. S l4 is still the Present Span, £p> The status of the Saved Span, 5 S , is left 
unchanged, thereby remaining invalid. 



43A) 
43B) 
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43) 2109, 2106, 2110, and 2300 Because the right edge of the display screen has not been reached (Le,,z CL <j mja ) 
tod also because 5 P is valid and S N is not valid. Rule 2 ii invoked to process £, 4 . 

2302 The Current Portion, S c (Le^5 14 to the right of jc^X most be completely visible. Therefore, 
render the Present Span, Sp (Le^ S 14 X from j^x tox& (Le, from to* 14R ). 
2304 and 2306 Because the Saved Span, S s , is not valid, there wis not an mtersectmg span that 
reduced the size of % Therefore, a query is done to look for an Abutting Span. The query performs, in 
each SMCCAM Word 900: 

F .Q - f -V A - * M R> A = W ^ 108> 

This query creates the set of all Abutting Spans for the Current Portion, S c (Le. 5 l4 to the right of jcor) 
and stores them in Fq. The query does not find any spans, so Fq is empty. 
43C) 2308 and 2320 Because Fq is empty, there is not an Abutting Span. All spans completely to the left of 
X CR < Lc "*ur) niust be hidden, so they are declared invalid. This is done by a query that performs, in 
each SMCCAM Word 900: 

f -v c ^vM'ar^cr) 

F r= F * (* * r \ (EQ 109) 

'.V e **V A < X iiR >jc I4R' 

This query reduces the number o f valid spans by reducing the spans in set F v from 2 to 1 . At this point, 
Fy consists only of 5j. 

43D) 2322 There is neither a valid Present Span, Sp nor a valid New Span, S s . Hence, both are labelled as 
invalid. 

S p s invalid; 

5 N = invalid; (EQ110) 

43E) 2324 The Current Portion, 5c, is set equal to: 

X CL e X CR B X I4R ; X CR e invalid; 
*CL e infinity; * C R " invalid; ff Q ni) 

Xqp « infinity; 

44) 2109, 2106, 2108, and 2200 Because the right edge of the display screen has not been reached (it^x^ <jc bux ) 
and also because the Present Span, is not valid and f v is not empty (indicating that at least some spans are 
valid). Rule 1 is invoked Here, Rule 1 is used to search for the frontmost span at* UR . When found, this 
frontmost span is processed as the Present Span,5p. 

44A) 2202 Do a query to find all valid spans that could affect the current raster line atJCa,(Le,z MR ). The 
query performs, in each SMCCAM Word 900: 

F„ = F a(x £x \ (HI 112) 

This query finds only S v The query operation could include z coordinate comparisons that check for 
values less than Zq* which has been set to infinity. 
44B) 2204 and 2222 Because Fq is not empty, there must be at least one span that could affect the current 
raster line at x^ (Le^ x M \ Therefore, the first span in F Q is read and made the New Span, 5 N . This 
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read operation sets the fbDowiog values: 

5 N e read(n) = 1; 

*nl s » 'itf *nr - ««!(J R ) « r 1R ; ^ 

</ N = read(d) = d x \ i N e read(i) = i % ; 

Reading &efim span yields the leftn^ from 
Fq by setting (f 1Q sO). 

44C) 2224 The j value for the New Span, 5 N (L*. at the j: coordinate (Le,jr 14R ) is computed as 
*tanp* 

2 iemp = *NL + (*CL" X Nl) d t4 = 2 IL * <*MR "*1L> d \ ffQ 1 14) 

The position (x 14R , 271 6 is shown in Figure 27. 
44D) 2226, 2228, and 2232 The computed value, is less than (Le. infinity), so make the New 
Span, S N (Le„ 5,), into the Present Span, Sj* by selling: 

S p = 5 N = 1; 
*PL = *NL s *PR = *NR c *1rI 

*PL - *NL " *l L i 2 PR e *NR = ^ " S> 

44E) 2236 The Current Portion, 5 0 is set to the portion of the Present Span, S P (ix^S,) to the right of 
*CL * mr) by setting: 

*CR = X HR m 

2 CL " 2 ump ; 2 CR c 2 NR = 2 lRl (EQ 116) 

CF C m **(*temp' W ° ""('uap^lR) - *t*m ? '> 

44F) 2237, 2204, 2206, and 221 4 Because F Q is empty and S P (Le. S,) » valid, a search is done for spans 
that could possibly occlude the Current Portion. Sq. (Le„ ^ to the right of x l4St ). The Span Occluding 
Test query performs, in each SMCCAM Word 800: 

f .Q » F .y* (»*S p ) A (X^<X CU ) A (X JiR >0f CL ) A [ (2 -L <2 cp ) V (Z^Z^)) 
F *Q - '.V* («*8) A (X -L < JC1R ) A (X -R >X MR ) A [ (Z^<Z tmp ) V (2 aR <Z ltaip )] 

This query creates the set of ail Potentially Occluding Spans for the Current Portion, S c (Le, 5, to the 
right of jc 14R X The query does not find any spans, so F, q is empty. 
44G) 2216 and 2220 Because Fq is empty, there must not be any spans that possibly occlude the Current 
Portion, S c (U„ Sj to the right ofx M ). Therefore, the New Span, S s , is labelled as invalid. 

S N = invalid; (EQ118) 

A read operation is not done. Si is still the Present Span, S P The status of the Saved Spin, 5 S , is left 
unchanged, thereby remaining invalid. 
45) 2109, 2106, 2110, and 2300 Because the right edge of the display screen has not been reached (Lc^cl < x^) 
and also because S P is vato and S N is not valio\Ruk 2 

45 A) 2302 The Current Portion, 5 C (LcSj to the right of x UK \ must be completely visible. Therefore. 
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render the Present Span, S P fix, 5 X X fromx^ to x^ fix, from* 14R to*^). 
45B) 2304 and 2306 Because the Saved Span, S s , is not valid, there was not an intersecting span that 
reduced the size of S c . Therefore, a query is done to look for an Abutting Span. The query performs, in 
each SMCCAM Word 900: 

Tliis query creates the set of all Abutting Spans for the Current Portion, S c (Le, S, to the right of* 14R ) 
and stores them in Fq. The query does not find any spans, so F Q is empty. 
45C) 2308 and 2320 Because F Q is empty, there is not an Abutting Span. All spans completely to the left of 
*CR (i.e.,* 14R ) must be hidden, so they are declared invalid. This is done by a query that performs, in 
each SMCCAM Word 900: 



F *v = f .v A < X j.R >jc CR 
F .v-*.vM*.»>*it: 



This query reduces the number of valid spans by reducing the spans in set F v from one to zero. At this 
point, F v is empty. 

45D) 2322 There is neither a valid Present Span, nor a valid New Span, 5 N . Hence, both are labelled as 



invalid. 



S p e invalid; 

5 N = invalid; W 21 ) 

45E) 2324 The Current Portion, S c , is set equal to: 

*CL m *CR e *1R*» *CR " inv *Hd; 

2 CL = inr >nity; * CR = invalid; (Eq 12 2) 

z CF «= infinity; 

46) 2106, 2108, and 2120 Because the Present Span. is not valid and F v is empty, all the spans have been 
processed. Since x^ (Le„ x 1R ) must be leas than x^, there is still a fraction of the current raster line to the right 
oU cl *ir) that has not been covered by spans. Therefore, the background is rendered fromxcL fix. Xls ) to 
Xuu. The Segment Span Rasterization Method 21 00 is complete for the current raster line. 
Timing of Processing within the Span Sorting Pipeline 400 

The Generic 3D Graphics Pipeline 200 generally utilizes a double buffered frame buffer 224 with two pages of mem- 
ory. This allows an image in one page to be displayed on the display device, while the rendering process writes an image into the 
other page. Image data is written to random locations within the display screen 104 because the geometry is fed into the pipeline 
without any spatial sorting. When scene rendering is complete, the pages are swapped and the next scene is rendered. 
Using only a few raster lines of display memory 

The Span Sorting Rendering Pipeline 400 generates the complete pixel coloring for a raster line before proceeding to 
the next raster line. If raster line rendering is done at a rate to keep up with the display, then only a few raster lines of Raster line 
Memory 416 are needed. 

Figure 28 shows how the timing of processing within the Span Sorting Rendering Pipeline 400 can be accomplished 
with only two raster lines of Raster line Memory 41 6. In this figure, the horizontal axis is time, where each tick mark represents 
the time to display one raster line on the physical display device (CRT, etc.). Polygon processing 1400 for scene 1 2802 writes 
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all the polygons in the scene into the Bucket Sort Memory 404. Once this 2802 is completed, raster line 0 U rendered 2804 for 
scene 1. When rendering this fire t raster line 2804 is corrmleted, the di^ 

provided that subsequent raster lilies tre ofnSm 
ter lines 2808 is in lock step with displaying of raster lines 2806, and only two raster lines of Raster Line Memory 41 6 are 
needed, one for writing while a raster line is processed, and one for reading to send data to the display device. Once polygon 
processing 1400 for scene 1 2802 is amrolete. j»rys^n pro^^ 

parallel (in a pipelined fashion) with processing raster lines for scene 1 2808 and displaying raster lines for scene 1 2806. 

The diagram of Figure 28 is an ideal case because processing a raster line 2808 is assumed to be very closely matched 
to the time it takes to dispky a raster line. In practical systems, there is some variation in the time it takes to process a raster line. 
Therefore, several raster lines should be processed before the corresponding scene is displayed, thereby providing some "slack" 
in the timing requirements. The diagram of Figure 28 also neglects display timing issues such as horizontal and vertical retrace 
times, but these can be used to introduce some of the "slop* in the timing. 

Having less memory than a full frame buffer is possible because pixel coloration processing is proportional to the 
number of pixels in the display screen rather than to the number of pixels in all the polygon spans in the raster line. When render- 
ing timing is done this way, the latency through the Span Sorting Rendering Pipeline 400 is mostly in the process polygon 1400 
portion. If the polygon processing 1 400 can keep up with the display screen rate, then a new scene can be displayed every time 
the screen of the display device is refreshed. 

The diagram of Figure 28 assumes, when a new scene is displayed, raster line 0 of the scene must be displayed first. 
This assumption requires polygon processing 2802 and raster line processing 2808 to "sync up" with the display device 2806. 
An alternate approach is to let the polygon processing complete at any point with in the cycle2806 of the display device, and to 
begin raster line rendering at the raster line that is about to be displayed (taking into account the latency of processing a raster 
line). This alternate approach requires the Bucket Sort Memory 404 to be able to start its read operation at any raster line. 

Some display screens, such as standard televisions, use an interlaced display of the raster lines. That is the even num- 
bered raster lines are displayed first (in the even "field"*) and the odd numbered raster lines are displayed next (in the odd "field"). 
For this type of display, the Span Sorting Rendering Pipeline 400 generates raster lines in the order needed by the display. The 
two fields of the display can be treated as separate scenes, or as a single interlaced scene. 
Using a single buffered display memory 

Figure 28 assumes only a few raster lines are stored in the Raster line Memory 41 6. An alternate approach is to have 
memory for all the raster lines in the Raster Line Memory 416. This increases the required memory by quite a lot (maybe by a 
factor of 100). but most computer video display systems have memory for every pixel in the screen, and 3D rendering maybe 
considered an add-on to this type of computer display. Hence, the required memory may already present in the video memory of 
the host computer system. 

This section of the document assumes the Raster Lane Memory 41 6 stores all pixel color information for every raster 
line. Figure 29 shows the timing for a display device with ten raster lines (practical displays generally have on the order of 1000 
raster lines) being continuously refreshed, where three screens worth of raster lines are displayed2902. As in the previous fig- 
ure, the horizontal axis is time, where each tick mark represents the time to display one raster line on the physical display device. 
At at some point within the display of a scene 2904, polygon processing 1400 will be completed 2806 for the next scene, and 
this point 2906 is not assumed to be tyiichronized with the scene display in any particular way. Completion 2906 of polygon 
processing 1400 means that raster line processing 2907 can begin. Processing raster line 02908 is done first, and this raster 
line is displayed the next rime 291 0 raster line 0 is sent to the display device. Similarly, the last raster line is processed 291 2 and 
subsequently displayed 2914, thereby displaying 2916 the entire scene. Figure 29 shows how, upon completion 2906 of a 
scene's polygon processing 1 400, the scene can be displayed beginning at the very next refresh cycle 291 6 of the display, even 
though the raster line processing of the last raster line 291 2 occurs after display of the first raster line 291 0. If both the polygon 
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processing and the raster line processing for entire scenes can keep up with the dispUy device's screen refresh rate, then anew 
scene can be displayed at every screen refresh. It once in a while, cither the polygon processing or the raster line processing 
does not keep up, then the display device may show the same scene on two consecutive display refresh cycles. 

The concept behind Figure 29 can be extended to 
display refresh cycles. That ss, as long as the raster line processing of the last raster line 291 2 is completed before it is 
displayed 2914, then the entire scene will be displayed correctly. Furthermore, raster line processing can start on the raster line 
that has most recently been displayed. Figure 30 shows polygon processing 1 400 completing 3002 just before raster line 7 is 
completely displayed. Raster line processing 3004 can begin with raster line 7 3006, and mis raster line is displayed 3008 the 
next time the display device shows it. Display of the scene is not intermixed with display of the previous scene (that is, there is a 
clean transition) provided the last raster line processed 3010 is completed before it is displayed 301 2. In this way, the maximum 
time to process all rasters 301 4 is almost as long as two screen refresh cycles. Hence, the processing of each raster line can be 
about twice as long as the time to display it without requiring the need for double buffering, only a single buffer is needed. 

The concept illustrated in Figure 30 of having raster line processing 3004 cover more that one screen refresh cycles, 
can be modified to have raster line processing 3004 wait until raster line 0 is displayed, thereby synchronizing with the refresh 
cycles. Polygon processing 1400 for the next scene does not need to wait because the Bucket Sort Memory 404 is double buff- 
ered. 

Using a double buffered display memory 

The Span Sorting Rendering Pipeline 400 can function with a fully double buffered Raster Line Memory 416. where 
every pixel in the display screen 104 corresponds to two words of memory (one in each buffer page). In this configuration, poly- 
gon processing 1400 for a scene is done until completed, then raster line processing is done until all raster lines in the display 
screen 104 have been processed, then the scene is shown on the display device. Thii approach has the advantage of being able to 
take as long as necessary without being constrained to display device timing. This approach has the disadvantage of introducing 
an additional stage of latency. 
Query Processor Architecture 

Within the Span Sorting Rendering Architecture 500 of Figure 5, for each raster line, the Query Processor 510 
receives spans from the Span Generation Processor 508. determines the visible span portions (as described above), and sends the 
visible span portions to the Rasterize Processor 510. A block diagram of the Query Processor 510 is shown in Figure 31, along 
with the two pages within the Span Memory 408. 

While one Span Memory Page 800 is receiving Span Parameters from the Span Generation Processor 508, the other 
page 800 is being queried to determine the visible span portions. The two pages 800 are swapped via the Query Processor 
Crossbar 3102, which is a set of multiplexors. The Query Processor 510 includes a register file 31 04 that is subdivided into five 
sets of registers for storing Span Parameters: 1) registers 31 06 for the Current Portion, 5 C ; 2) registers 3108 for the Present 
Span, 5 P ; 3) registers 3110 for the New Span, S N ; 4) registers 3112 for the Saved Span, 5 S ; and 5) temporary registers 3114 
used for things such as span intersection locations. 

The Query Processor Control 31 1 6 determines the sequence of operations in the Query Processor 510, including the 
sequence of query operations. As raster line processing proceeds, branches within the method1800 or 2100 depend on query 
outcomes, span status, and Span Interaction Types (SITs). For each pair of and S N , the SIT and SIP Logic 3118 generates the 
Span Interaction Type. Computing a SIT requires the operations of Eolation 10 to be performed, as well as various comparison 
operations. These operations are performed in the Compare and Offset Computation 3200 block on data received from the regis- 
ter file 31 04. Whenever Rule 4 2500 is invoked, the intersection point between 5 C and 5 N is computed in the Intersection Com- 
putation block. 

For maximum throughput, Compare and Offset Computation 3200 can be implemented in parallel hardware. 
Figure 32 shows four identical blocks 3202, where each block 3202 includes two arithmetic comparators 3204 and 3206, a 
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■ubtracte 3208, «nd« multiple 3m 10 
The comparators generate gignmls thai an be wed to generate the Span Interaction Parameters (SIPs). Inputs to the Nocks3202 
come from the register file 31 04, and outputs go to the SIT and SIP Logic 311 8. 
Sorting Magnitude Comparison CAM Circuits 

Figure 33 .hows a prior art MCCAM bit cell 3300, taken from the Duluk Patent, constructed out of CMOS transistors 
and gates. A field within an MCCAM Word can be built with a multiplicity of these cell; 3300. In this cell 3300. one bit is 
stored in a Six Transistor RAM Subcircuit 3302, where reading and writing is controlled by the signal CamWord 3304 and data 
is written and tead via the differential bit lines, BUM 3306 and BitL 3308 (the TT and at the end nf ri r .1 ;^ ifttw 
active high and active low. respectively). During a query operation, the XOR Subchcuit3310 performs an exclusive-or function 
to produce the signal NotEqual 331 2, which indicates the bit value stored in the RAM 3302 is not equal to the bit value on the 
bit lines 3306 and 3308. During a query operation, the signal EncbUln 3314 being asserted indicates higher order bits in the 
field are all equal and this bit position is enabled for comparison. If Atorfioua/3312 is at logic "0" when EnaMe/»3314 is 
asserted, the Precharged Enable Propagation Subcircuit3316 enables the nat lower bit position by asserting EnableOut 3318. 
If NotEqual 3312 is at logic "1" whtnEnabUIn 3314 is asserted, the Two Transistor Query Resolution Subcircuit3320 condi- 
tionally pulls down the QueryTrue33U signal, depending on the value of CemparisenOp 3324 (as described in the Duluk 
Patent), and EnabUOut 3318 remains unasserted. 

In contrast to an MCCAM. an SMCCAM 800 (recall the "S" stands for "sorting-) can shift data from one word 800 
to the next during a sorting operation, figure 34 is a TIL type" circuit for one bit in an SMCCAM Word BOO. This cell 3400 
includes a master-slave flip-flop 3402 for storing the bit value beam* it must function a. a tut in a shift register. The cell is 
shown with separate I/O lines. InpulBil 3404 and OutputBUMK. but a single bidirectional I/O line or a bidirectional differen- 
tial pair could be used. A read operation is done by asserting the Read 3408 control line, which enables the tri-atate buffer 341 0. 
A write operation is done on the rising edge of Clock 3412 when WriteEn 3414 is asserted and ShiftEn 3416 is not asserted. 
The shift within a son operation is done on the rising edge of Clock 3412 when WriteEn 341 4 is asserted and ShiftEn 3416 is 
also asserted. The signal ShiftEn 3416 controls a multiplexor 3418 that chooses whether data on InputBU 3404 or data on 
Shiftln 3420 is stored into the flip-flop 3402. Data on Shifiln 3420 come from ShiftOul 3422 in the corresponding cell 3400 „ 
the previous SMCCAM Word 900. Query operation! function similarly to the MCCAM of the Duluk Patent. That is. an 
exclusive-or 3424 generates the signal NotEqual 331 2, which is used to generate EnableOut 3318 and the word's query result. 
StoredGreaterlU2$. The key differences in the query operation function are: 1) the absence otComparisonOp 3324 in the 
cell: and 2) an open collector circuit 3428 to generate the query result 

Figure 35 is a 27-transistor CMOS circuit for one bit in an SMCCAM Word 900. This cell 3500 includes a Six Tran- 
sistor RAM Subdrcuit 3302 as the master part of the flip-flop, and a Slave Memory Subeircuit3502 as the slave part of the flip- 
flop. The Six Transistor RAM Subcircuit 3302 is used in me conventional way for read and write operations, and the Slave 
Memory Subcircuit 3502 is only used during shifting. To allow a bit to be shifted into the Six Transistor RAM Subcircuit3302. 
a Shift Write Subcircuit is included in the cell 3504. The following sequence occurs (in this example cell 3500) when shifting is 
done: 1) the differential clock signal ShiftToSlaveH 3506 and ShiftToSlaveL 3508 is asserted then de-asserted in order to latch 
the data bit into the Slave Memory Subcircuit3502; 2) the data bit is output from the cell to the corresponding cell 3500 in the 
next word 900 via the differential signal ShiflDataOulH 3510 and Jfc)U)ataOjiiL3512; and 3) the data bit is received on the 
differential signal ShiflDalalnH 3514 and ShiftDalalnL 3516 m the next word 800 and is written into that cell 3500 by assert- 
ing ShiftEnable 351 8. 

Certainly, there are many bit cell circuits that could be designed to do an equivalent function. To illustrate some of the 
other choices, the cell in Figure 35 uses a Non-Precharged Enable Propagation Subcircuit3520 and a Three Transistor Query 
Resolution Subcircuit 3522. Note that the Slave Memory Subcircuit 3502 is a dynamic eircuit. and it could be replaced with 
many other types of latches, including a static latch. 
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Figure36 is a 23-tranristor CMOS circuit for one bit in an SMCGAM WordOOO. This ceU3600 utilizes a 
12-transistor Master-Slave Memory Subcircuit3602 that uses dynamic storage in both the master and slave halves of thefiip- 
flop. The main advantage of this cell is reduced chip area due to both a smaller number of transistors and the significant number 
of series transistors (series transistors tatetm less space because 

BitlnH 3604, is written into the master half of the flip-flop 3602 by asserting the differential signal pair composed of 
WrileToMaaerH 3606 and WrileToMasterL 3608. During the other half of a clock cycle, the data bit is stored into the slave half 
of the flip-flop 3602 by asserting the differential signal pair composed oiShiflToSlaveH 3610 and ShiftToSlaveL 3612. A data 
bit from the corresponding bit in the previous word is shifted in vi&ShiflDaialnH 351 4 into the master half of the flip-flop 3602 
by asserting the differential signal pair composed otShiflToMasterH 361 6 and ShiflToMasUrL 361 8. The stored data bit is read 
from the ceil 3600 by asserting ReadWord 3620, which puts the inverted bit value onto thcBUOulL 3622 bus. The balance of 
the cell 3600 performs the comparison and enable chain in a manner similar to the cell 3500 described above. The XOR Subcir- 
cuit compares the stored bit value (utilizing both the master and slave values flip-flop3602 because they are compliments of 
each other) and the complementary values onBUInH 3604 ndBUInL 3624. 

Figure 37 shows an array of CMOS SMCCAM bit cells forming a set of flelds. The signals. ShiftDaialnH 3514 and 
ShiftDaiaJnL 351 6, are grounded in the first word 900 because the first word 800 cannot have data shifted into it 900. 

When signed numbers need to be stored into the SMCCAM. it is simplest to invert the sign bit (Le. t "1* implies posi- 
tive) during both the reading and writing processes. That way. in the hardware* positive numbers are -bigger" than negative num- 
bers. An alternate approach is to change the bgic in the sign bit petitions in every field where a rigned number ne«ls to be stored 
and queried. Floating point numbers are easily stored by putting the exponent in a more significant set of bit positions and by 
storing the exponent as a positive number. Hence. IEEE floating point standard numbers will be processed correctly. 
Multiple Spans Vertically within a Raster line 

In the Segment Span Rasterization Method 2100 as described above, each polygon can have only one span in a given 
raster line, and that span is represented by a line segment (hence, the name 21 00) parallel to the x>y plane in screen coordinates. 
The location of the endpoints of spans are in object-precision, and therefore can be located anywhere horizontally within a 
pixel s boundaries. For example, if the end a span covers 20% of the width of a pixel, then that span accounts for 20% of the 
color value for that pixel, and is blended with color value for the other 80% of the pixel width. This provides for horizontal ami- 
aliasing, but not vertical antialiasing. That is. blending occurs horizontally, but not vertically. If the edge of a polygon is closer to 
horizontal than vertical, then the edge has a good chance of crossing through multiple pixel areas, meaning that the polygon 
color should be blended into multiple pixels. However, when a single line segment is used to represent the span, the polygon's 
color is bknded into one pixel (the orie that includes tr* segmmt sp 

ered 100%, and are not blended (assuming visible span portions are wider than one pixel). Lack of vertical antialiasing is accept- 
able for some applications, but high quality images should be both antialiased in both directions. 

One method of adding vertical antialiasing is to divide each raster line vertically into several "sub-raster" lines. Then, 
the Segment Span Rasterization Method 21 00 can be used for each sub-raster, and pixel color values can be generated by blend- 
ing vertically as well as horizontally. Figure 38A shows a raster line 3802 and its pixels 3804. two edges of a polygon 3806 
and 3808. and two sub-raster spans 3810 and 381 2 for that polygon. Similarly, Figure 38B shows four sub-raster 
spans 3814, 381 6, 3828, and 3820 for the polygon. As a possible variation, if a pixel is covered by only two such sub-raster 
spans from the same polygon, it would be possible to compute one color value at the center of the pixel 

Using sub-raster lines reduces vertical aliasing, but does not eliminate iL For many applications, this is an acceptable 
approximation. 

Trapezoidal Span Rasterization Method 

Spans can be represented by two-dimensional trapezoids rather than one-dimensional line segments. Both line seg- 
ments and planar trapezoids are in three-dimensional object-precision eye coordinates. The advantage of a trapezoidal represen- 
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tation is the preservation of edge information within a raster line, thereby providing correct antialiasing in both the horizontal 
and vertical dimensions. 

Figure 39 shows a triangle mesh with two triangles 3902, and 3904. and one raster line 3906 within the display 
screen104. The area within the raster line 3906 for each triangle 3902, and 3904 is a trapezoidally shaped span, labelled 
3908 and S i2 391 0. For tt fljwnirl a l spans, the span f nrinoi n t is an edge of the trapezoid, and ts described by two points in 
three-dimensional screen coordinate: one at me top edge of tte 
a trapezoidal span is described by four r^ 

ure has endpoints described inx-z space by. 1) the top of the left endpoint located at (? llL p r iuj ); 2) the bottom of the left end- 
point located at (x 11LB , r 11LB ); 3) the top of the right endpoint located at (x iurr z xm ); and 4) the bottom of the right endpoint 
located at C* 11RB , 2 llRB ). These four points are actually inx-y-z space, but the y<oordinate is dictated by the location of either 
the top or the bottom of the raster line 3906. Note that the subscripts in the coordinate variables indicate three things: 1 ) the span 
number (eg., "11"); 2) the left or right endpoint (U. **L M or "IT); and 3) the top or bottom of the raster line (i-e., T or "B"). 

An opaque trapezoidal span occludes more distant geometry over most of its length, but at endpoints39l 2, and 391 4 
that are not abutted to another trapezoidal span, more distant geometry is partially visible. However, for abutting trapezoidal 
15 spans, as shown in Figure 39, the common endpoint 391 6 does occlude more distant geometry. This presents a problem when 
utilizing trapezoidal spans. That is, non-abutting trapezoidal span endpoints do not occlude more distant geometry, but abutting 
endpoints work together to occlude 391 8 more distant geometry. The invention of this document successfully solves this prob- 
lem by searching for abutting spans. 

Figure 40 shows a group of trapezoidal spans in the same raster line, and these spans are trapezoidal versions of the 
segment spans shown in Figure 1 1. In Figure 4a the visible portions of the spans are shaded. Notice that for spans in a polygon 
mesh (Le. abutting spans), span tops lay end-to-end with each other, and span bottoms do likewise. Span endpoints cast an edge 
-shadow- onto spans that are farther from the viewing point For example, the left endpoint 400 2 of 5 2 casts such a 
shadow 4004 onto S x . 

An additional concern when using trapezoidal spans occurs when a polygon crosses either the top or the bottom of the 
25 raster line, but not both. This would generally happen at 1) the corner of a polygon 2) at a horizontal edge of a polygon; or 
3) when occluding spans leave only a sliver of a span visible. One example of this is shown in Figure 40, where the far right 
end 4006 of S 0 is visible. In this type of situation, the trapezoidal span is actually shaped like a triangle, and therefore could be 
considered a "degenerate trapezoid*' where the top or bottom is of length zero. 

Ibis document has explained in great detail the Segment Span Rasterization Method 21 00, and the Trapezoidal Span 
30 Rasterization Method is similar in that it follows the fxontraost spans from left to right and sending the visible portions of spans 
to the Rasterization Processor 512. The key difference is that non-abutting endpoints of trapezoidal spans do not fully occlude 
more distant geometry. The Trapezoidal Span Rasterization Method must correctly handle these types of spans. 

There is a variety of ways to handle trapezoidally shaped spans. Rather than having a method flow diagram for each of 
the four choices for the Trapezoidal Span Rasterization Method presented here, the features of each choice will be explained, 
35 along with the corresponding choices for SOT Queries. These four particular choices were selected to illustrate how the raster- 
ization method presented here can be expanded to process trapezoidally yhfrrd spans. 
Version 1: Occlusion processing dome separately for span tops and spam *^«pffff 

A trapezoidal span can be described as the collection of: 1) a span top, the line segment on the boundary of the trape- 
zoidal span along the top of the raster line; 2) a span bottom, the line segment along the bottom of the raster line; and 3) the area 
40 between the span top and the span bottom. The version of the Trapezoidal Span Rasterization Method described in the section of 
the document does occluding processing on span tops separately from span bottoms. This can be done because, for the same ras- 
ter line, span tops and span bottoms never occlude each other. Occlusion processing for span tops can be done in the same way 
occlusion processing is done for segment spans in the Segment Span Rasterization Method 21 00. Occlusion processing for span 
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bottoms can be done separately in the same way, and should be dooe in parallel wilh occlusion processing of span tops in order 
far pairs of tops and bottoms to be comedy paired far pixel color generation. 

This version of the Trapezoidal Span Rasterization Method keeps track of the following "span-like* things (including 
appropriate endpoints): 1) the Present Span,5p the trapezoidal span that is currently being f» rtfd to see what part of it should be 
rendered; 2) the Currerit Span To^ 

the bottom edge of the S P that is being tested for visibility; 4) the New Spao,S N , the trapezoidal span recently read from the Span 
Memory 408; 5) the New Span Top, the top edge of % 6) the New Span Bottom, S m . the bottom edge of S H ; 7) the Top 
Saved Span, S CTt a trapezoidal span mat is temporarily saved because 5^ intersects S^v in » situation analogous to Rule 4 
described above; and 8) the Bottom Saved Span. a trapezoidal span that is temporarily saved because 5^ intersects 5^. 
Two different saved spans are needed because span tops are processed separately from span bottoms, and they could have inter- 
sections with different spans. Keeping track of more information during rasterization requires more registers to be added to the 
Span Parameter Registers 3104 within the Query Processor 510. 

Figure 41 shows an enlarged version of the example spans Sj 4101 and S 2 4102 from Figure 40, and, 5, 4101 is 
assumed to be the Present Span, 5p> The span top of 5, 4101, calkd S ir 4103. has its corresponding SOT Region 41 04 that 
finds S2T 4106 occluding it 4103. This SOT Region 4104 does not find 4108 because it 4104 is only searching for span 
lops. Similarly, the span bottom of 5, . S lB 41 1 0, has its SOT Region 41 1 2 that finds 5 2 41 08 occluding it 41 1 0. 

Figure 42 shows two views of a partial set of spans within a raster line4200, labelled S 3l 4201 through S 39 4209. 
The upper diagram is thex-r vjew (the look direction is parallel to thcy-axis) of the spans, and the lower diagram isx-y view (the 
look direction is parallel to the z-axis) of the same spans. In the lower view, hidden portions of the spans are not shown, and 
therefore represent how an infinite precision rendering of the spans would be drawn for that raster line4200. But. since the dis- 
play device does not have infinite precision, span colors must be blended together in correct proportions for each pixel In the fig. 
ure, visible portions of span tops and bottoms are shown as thicker lines. Visible portions of span tops and bottoms are passed to 
the Rasterization Processor 512 were they are used along with polygon edge derivatives to determine pixel colors. The spans in 
Figure 42 were chosen to illustrate handling of various cases, including spans where only the span top or span bottom is visible 
and also spans that do not cover the entire height of the raster line 4200. 

Just as in the Segment Span Rasterization Method 21 00, the spans are processed in a left-to-right manner. The exam- 
ple of Figure 42 starts in the middle (ije„ horizontally) of the raster line whereS 3 , 4201 is5 F £ 3lT 4211 isS CT andS 3lB 4221 
isScB. The SOT Queries for Scrand $CB find nothing, S N is set to invalid, and by a rendering rule similar to Rule 22300 of the 
Segment Span Rasterization Method 21 00, 5 3 , 4201 is rendered to its right endpoint. The rendering of S n 4201 covers 100% 
of the pixels up to the one that includes 0f 31Kr 4251. From that point, the edge derivative for the corresponding polygon edge 
(see Equation 1) is used to determine the percent coverage of each pixel, and this percentage weighti the pixel color. The 
span 4201 can be rendered to its right endpoint because the entire length of the endpoint (the endpoint of a trapezoidal span is a 
line segment) is guaranteed to be visible. Also by the Rule 2 2300 analog, queries for abutting span tops and span bottoms find 
S m 42 1 2 and 5 32B 4222. At this point in the method. S 32 4202 is S m 421 2 is S CT and 4222 is 5^. Tbe SOT Que- 
ries for S CT and Sqb find nothing, and abutting spans are also not found. Hence, 5 N is set to invalid. 

By a rule similar to Rule 22300, 5 M 4202 is rendered in its entirety ft* right endpoint is guaranteed visible), and 
edge derivanves are again used to compute pixel coverage. To sight an example, for the pixels at least partly contained between 
*3iKT 4251 ""i *31RB 4252 « the sum of percent coverage due to S 31 4201 and S 32 4202 totals 100%. Queries to find abutting 
span tops or bottoms fail so all spans completely to the left ofx 32RB 4252 are invalidated, and both S P and S N are set to invalid. 

By a rule similar to Rule 1 2200, a search is done to find the rrontmost span tops and bottoms 1**3^4253 and 
*32RB 4254 * whk h finds 5 33 4203 and assigns it to 5^ sets £ CT to the part of S m 421 3 to the left of* 32Kr 4254, and sets 
to the part of S 33B 4223 to the left ofx^^ 4253. The SOT Queries for S CT and S CT S MT 421 4 and 5 35B 4225 (note these 
are from different spans) which are assigned to and S^, respectively. S N is set to 4204, rather than 5 33 4205 because 
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Ihe visible portion of 4204 is farther to the left, and the method proceeds from left to right 

By a rule similar to Rule 3 2400, ^4203 is rendered, but only partially. At this point, the Rasterization 
Processor 512 can only render it 4203 to x 3aT 4255 hrransr its 4203 area to the right of jt*^ 4255 still needs to have its vis- 
ibility determined (generally the case when and are not from the same span). Becausej^gr 4255 almost certainly does 
5 not align with a pixel edge, the pixel that includes 0^^4255 is partially colored by the portion of S33 4203 that is know to 
cover it (and the rest added later). Alternatively, the entire color contribution to that pixel by S33 4203 can be postponed until the 
entire amount of pixel coverage is known. At this point in the method, 534 4204 is 4214 is and $333 4225 is 5^. 

The SOT Query for £ CT (Le^ Sycj 421 4) finds S m 4215 *"* makes it S m Because this 5^- matches S m of the previous step 
(Lc. they are from the same span, 4205% the SOT Query far Sq, 0x^^4225) is postponed to the next step in the 
10 method. S N is set to S 35 4205. 

During the method, when and 5^ are not from the same span, previous spans can only be rendered to the leftmost 
of either the current x-value position along the top of the raster line and the currenU-vahie position along the bottom of the raster 
line. At the leftmost of the two x- values, all span to the left has been considered, and so rendering can be done. 

By a rule similar to Rule 3 2400, S34 4204 is rendered by the Rasterization Processor 51 2. This time, S m and S m 
15 are from the same span, so S M 4204 is rendered up to the left endpoint of $33 4205. Also, rendering of S 33 4203 can be com* 
pleted because its visibility has now been determined. At this point in the method, J 33 4202 is made 5 P S m 4215 is made S CT 
and 5 35B 4225 is made 5^. The SOT Query forS CT (i-e.. %r 4215) finds S m 4217 making itS^ while the SOT Query for 
Sqb ft- c - <?33B 4225) finds nothing, and makes S^b invalid. S N is set to S37 4207. 

By a rule similar to Rule 3 2400, £35 4205 is rendered from its left endpoint to 4256 because x^^ 4256 is the 
20 leftmost choice between x 35RB 4256 and x 37IX 4257. A search for an abutting span bottom to Sqb (Le-Sj3B 4225) finds 
$M 4226. At this point in the method, 5* 4206 is 5 P 4217 is 5 CT S#b 4226 is 5^. 5^ 4217 is and an SOT 
Query for 5 CB (U^ S M 4226) finds 5 39B 4229 and makes it 5^. 

By a rule similar to Rule 3 2400. S^, 4206 is rendered up to xj^j 4257 because xyjiy 4257 is the leftmost choice 
between x 37l j 4257 and * 39LB 4258. Also, rendering of 5 3J 4205 can be continued up to Xynj 4257. Because S 37 4207 is not 
25 hidden and is known to have only a span top (no span bottom), it 4207 is made Sp Also at this point, Syjj AZil is still S CT 
•S 39B 4229 is Scb. and query to find an abutting span to £37 4207 finds noting, so is invalid, and 4229 is still S^. 

By a rule similar to Rule 2 2300, 5 37 4207 is rendered in its entirety. Both 533 4205 and 5 M 4206 can now be ren- 
dered up to x z7KT 4259 (completing 5 35 4205) because it is the leftmost choice between 337^ 4259 and 4258. At this 
point, 5 38 4208 is 5 P 5 CT is invalid, S m 4229 is S m is invalid, and an SOT Query for 5^s S 3 9B 4220) finds nothing, 
30 so Sjto is invalid. 

By a rule similar to Rule 1 2200, a search is done to find the frontmost span top at Xyj^ 4259. This search finds 
S SST 421 8. and 5 CT is set to the portion of S m 421 8 to the right ofxyncr 4259. An SOT Query for 5 CT finds S m 421 9 which 
is assigned to S m At this point, 4208 is still S m 4220 is stall 5^, and S m is still invalid 

By a rule similar to Rule 3 2400, 5 M 4208 is rendered up to the left endpoint of £ 39B 4229. Because 5 39 4209 is 
35 going to be made into the next 5 p the other remaining uncompleted span, £35 4206, is completed by rendering it up to the left 
endpoint of £393 4229. Care must be taken to correctly account for all the polygons edge derivatives correctly. 

The raster line 4200 processing continues with S39 4209 as but the right edge of our example has been reached. If 
there had been some completely hidden spans within the left and right boundaries of mis example, they would have been com- 
pletely avoided by either never being found by an SOT Query or by being discarded by a rendering rule similar to Rule 52600. 
40 Similarly, if there had been an intersection between two span tops or two span bottoms, a rule similar to Rule 4 2500 would have 
been applied, and Saved Spans would have been used. 

A special case may be added for handling spans that either do not have either a span top or a span bottom (they are less 
than one pixel in height) or have both their span top and span bottom hidden, but are visible within the raster line (just peeking 
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out from between two nearly horizontal polygon edges). In most practical application*, such marginally visible items can be 
ignored. 

It is possible mat color information from several different spans are blended together for a particular pixel. Under such 
circumstances (and even for blending only two span's colors), only a reasonable approximation of the perce nt coverage is needed 
to make a high quality image. 

When implemented in hardware, this version of the Trapezoidal Span Rasterization Method uses one SMCCAM 
Word 000 for each span top and another one for each span bottom. Both the span tops and span bottoms could be stored into the 
same page within the Span Memory 408. This would mean timesharing the Span Memory 408 between two essentially inde- 
pendent occlusion processes, thereby reducing performance when compared to staring span tops and span bottoms into different 
pages. Using one page for occlusion implies the Span Memory 408 needs a total of two pages, as shown in Figure 39* to double 
buffer the spans. 

If two pages within the Span Memory 408 are used, the two occlusion processes can be done in parallel. However, 
some fields, such as the Span Derivative Field 81 2 and the Information Pointer Field 81 2, need to be duplicated they are 

needed by both occluding processes. Also, using two pages for occlusion processing tends to imply a total of four pages are 
needed in the Span Memory 408. But if a non-interlaced display device is used, men the set of span bottoms for the current ras- 
ter line is the same as the set of span tops for the next raster line. Hence, three total pages are needed in the Span Memory 408 
because one page is used for writing, and two pages are used for reading, and one of those two pages is reused for the next raster 
line. If an interlaced display device is used, then the same technique can be used, but raster line rendering order will not match 
the display device. 

Another alternative is saving the list of the visible bottom span portions (i<e* after occlusion processing) in another 
memory and then using them as the span tops in the next raster line. Such a memory could be included in the Rasterization 
Processor 51 2. While this is certainly possible, it is probably more economical to recompute the visible top spans. 
Version 2: Perform an SOT Query at every transition in the raster line 

In this version of the Trapezoidal Span Rasterization Method, spans are processed from left to right, but occlusion pro- 
cessing treats each span as a unit, not as a separate span top and a span bottom. To do this, SOT Regions are bounded on the right 
and left by a visibility transition on either span tops or span bottoms. 

Figure 43 shows an enlarged version of the example spans Sj 4301 and S 2 4302 from Figure 40. At the start of this 
example, 5 X 4301 is the Present Span, Sj» and x 1LB 4304 is the current ^-coordinate, x^. Hence, the raster line has been ren- 
dered upto* lLB 4304, including the part of 5, 4301 between j^uj 4303 andx^ 4304. The Current Span, 5 0 is the part of 5 P 
(Le., 5 2 4301 ) to the right of xq. *ilb 4304) that has the same visibility characteristic, namely the part betweeitx 1LB 4304 
'lFT 4306 (making x 1KT 4306 the value for Jt^). The visibility characteristic (otS t 4301 changes at x 1RT 4306 because to 
the right, the span 4301 does not occlude more distant geometry, while to the left of that point 4306, it does. The SOT 
Region 4308 for this S c is shown in Figure 43 and described by Equation 123. 

(EQ123) 

( X «RT < X Cl) V ( X mKB K X Cl) 1 
A 1 1 <*«LT < 2 CFT> V < 2 -LB < 2 CFB> 1 V I < Z .RT < 2 CFT> V <*«RB < *CFB> 1 1 
F .Q eF «V A ^ Q A <«*1) * [(X«L T <X 1RT ) V U JI LB < *1RT)1 a [<*«RT <Jf lLB) v < **RB < *ILB> 1 
A HU JlLT <2 |aiipl ) V U j|L b<Z 1L b)] V [(z. RT <2 lanpl ) V (2 wRB <2 1LB )]] 

There are two different z-values used in this query, z&t *TFB» because the span portion being tested for occlusion has differ- 
ent depth values for its top and bottom. The value forzepr is set to the maximum 2-value of the span top within thex-coordinate 
interval of 5 C . which happens to be ^-coordinate with the valuexitjt 4304, labelled 4309. The value z %mDpX 4309 is com- 
puted using the span derivative for 5} 4301. Similarly, the value for 2q?b is set to the maximum z-value of the span bottom 
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within the x-coordinatc interval of Sq. and this value is 4310. Tbe SOT Query finds 4302, and it 4302 is made 5^ 

By a rule similar to Rule 3 2400 of the Segment Span Rasterization Method 2100,Sp (Le^Sj 4301) is rendered from 

xo.(i-e- *ilb 4304) to the leftmost point of S N (Le^ 5 2 4302), which is jk^lb 4304. Over this interval, the visibility characterise 

tic does not change for the raster line, That is, 5i 4301 is the only geometry that is visible within the interval. 

The value ofjtQ, is changed to jc^ 4311, andS c is the top edge ci^ 4301 from Jt^j 4311 to 0^4312 combined 

with the bottom edge of5 2 4302 over the same interviL The v 

is consistent in that it includes S x 4301 gradually being covered by S 2 4302 ova its entire width. The corresponding Query 
Region 4313 is over the interval atS c in the x-coordinale dimension. But, in the incoordinate dWnrinn tpan top coordinates 
are tested to see if they are in front of 4314 and span bottom coordinates are tested to see if they are in front of22ij4316. 
The coordinate z laBp2 431 4 is the r-coordinaie of the span top of 5j 4301 at s-coordinste 4304. This Query Region 431 3 
needs to include a search for span tops that are between 431 4 and 4316 because a span with its left top corner in this 
range would be visible. The query operation is shown as Equation 124. 

f -Q = f -V^ -Q A <"**C> A K'aLT^CR) v <*«tB<*CR>l A I < *.RT < *Cl) V (* B RB<*CL>1 
A [ I {2 Hhr < Z cpr ) V {2 mlB < 2^) ) V [ (Z^Icp,.) V {Z M <2 cpB ) ] ] 

F *Q = f *v A,r , l Q A < rt5,tl ) A <"* 2 ) (EQ124) 

A [ (^j<X 2Lr ) V (X^ < J^ T ) J A [ (^ RT <^ 2LB ) V <* -RB <X 2UJ ) ] 

A H(i jiL t < v < 2 .lb <2 2lb>J v K*.rt< W> v (j -rb <2 iui)J] 

In this example, the Query Region 4313 finds rothing, so 5 N remains invalid. 

By a rule similar to Rule 2 2300, S c is not hidden, so it is rendered, resulting in a blending of S x 4301 and S 2 4302 
over the entire width of S c . The rule then M checks for** the equivalent of an abutting span, and this is known to exist because 
S 2 4302 continues to the right from 431 2. Therefore, 5 C is set to the part of S 2 4302 between x^ 431 2 and x^ 4318. 
and *a. is set to *2Lj4312. Once again (as always for this version of the method), 5 C has a consistent visibility characteristic 
over its entire width. The SOT Region 4320 for this 5 C is shown in Figure 43 and described by Equation 125. The value 
2 tanp3 4322 is the r-value of the span bottom of S 2 4302 at the ^-coordinate Xgj 431 2. 

(EQ125) 

f .Q B F *V* F »Q* <"* S C> A I <**LT <JC CR> V (*.LB<*Cr)] A I <*j.RT < X CL> V <*.RB < X C\) I 
A [ [ (2^ T <2 m ) V { 2kLB <2 CpB ) J V [ U M% j<2 crr ) V (I -RB <2 cpB )] ] 
F *Q = a a <n * 2) a [ { XaLT < X^j) V ( XmLB < X2 kr ) ) A I {x^j < *2LT> v (*»RB < *1Lt) I 
A 1 1 < 2 «LT<*2LT> V < 2 .LB <*l«n P 3>l V I ('.RT^ZLt) V <*i.RB < 1 1 

The rasterization of the spans in this raster line would continue from this point Tbii version of the method also has 
rules analogous to Rule 1 2200, Rule 4 2500, and Rule 5 2600. 

In general this version of the method takes spans, and subdivides them horizontally in order to create sections that 
have a consistent visibility characteristic This means that the endpoint regions of a span (the part that does not occlude distant 
geometry, such as the endpoints 3912 and 3914 in Figure 39) are treated separately from the central portion of the span. This 
causes more query operations to be n ee d e d, but can be done in a single occlusion process. 

This version of the Trapezoidal Span Rasterization Method requires more fields per SMCCAM Word 900 Wmsr 
there are four fields per endpoint rather than just two. Additional comparison logic is also needed in the Word Number Field802 
because it 802 must be able to check inequality with a Current Span that is the combination of two trapezoidal spans. In the 
above example, the value ofS c corresponding to the Query Region 4313 covering 4310 to xjlt 4312 is the combination 
of Si 4301 and S 2 4302. Hence, the SOT Query must check for both (n*l)and(n* 2), thereby requiring two inequality com* 
parisons during that query operation. This version of the method has the advantage of needing only one word 900 to store a 
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span. 

Version 3: More comparisons per word to allow more complex SOT Regions 

In this Ycraion of the Trapezoidal Span Rasterization Method, occlusion processing treats each span as a unit, just as in 
Version 2. However, this version performs more comparison operations in each SMCCAM WordOOO, thereby providing the 
ability to make more complicated SOT Region*. Rather than splitting spans si every visibility transition, the Current Span, SQ 
can contain one visibility transition. In essence, an SOT Region for this version is the union of two SOT Regions as defined in 
Version 2. Figure 44 shows the same two spans 4401 and 4402 as shown in Figure 43, and an SOT Region 4404 mat is the 
union of two SOT Regions 431 3 and 4320 from Version 2 of the method. To perform mis SOT Query, the query operation is 
the disjunction (Le., logical "or") of the right sides of Equation 124 and Equation 125. 

To perform the more complicated query function to generate the SOT Region 4404, the fields in each SMCCAM 
Word 900 each need to perform two comparison operations in parallel (if the two operations are done sequentially, then it is the 
same as Version 2). This makes the hardware more complicated, but will reduce the time to perform occlusion processing by 
about a factor of two. 

Version 4: Use a looser approximation of the Occluding Region 

Another choice to reduce the occlusion processing time is to use a looser approximation of the Occluding Region. For 
example, the "L-shaped" SOT Region 4404 in Figure 44 (which is a good approximation) can be made into a simple rectangular 
region by increasing its area. Figure 45 shows the same two spans 4501 and 4502 as shown in Figure 44, and an SOT 
Region 4504 that is larger and simpler than the SOT Region 4404 from Version 3 of the method. The SOT Query that generates 
this SOT Region 4504 is the combination of Equation 124 and Equation 125 such that the looser constraint is used for each 
field. The query operation is: 

F *Q = F *V* F mQ * < n **C> A K Jf -LT <JC CB> V <*«LB<*CR>1 A ' < *«RT < *CL> V <*.RB <X CL>1 

A I I <*nLT < W V < 2 *LB < *CFB> 1 V I <*-RT < W v <*aRB < W 1 1 
F *Q m F *v* f mQ a A a (EQ126) 

A K'aLT* *2ET> V < **LB < *2RT> ) A K jr .RT < '2LB> V <*.RB<*2LB>1 

A [ [ (Z^ r < 2 Ump7 ) V < 2^) J V [ ( 2jJlT < 2|emp2 ) V (Z M < 2aLB ) ] ] 

When this looser approximation is used for the SOT Region 4504, more Potentially Occluding Spans (on the average) 
that are actually hidden will be found, thereby reducing performance. However, this may yield a net gain because the number of 
query operations is reduced. 
Transparency 

The Span Sorting Rendering Architecture 500 can render transparent geometry (colored geometry that can be seen 
through) by generating its spans in the same way as those for opaque geometry. Translucency can be handled in a similar way, 
but this document focuses on transparency. To aid in the rasterization process, the rxansparency of each span is marked in the 
Span Memory 408 by one of three methods: 1) another flag bit, F m ^ is added to each word 900; 2) a bit in the Information 
Pointer Field 814; or 3) another field, a Translucency Held, is added to each word 900. The opacity coefficient (Le., the amount 
of light transmitted by the transparent geometry) is stored in the Polygon Information Memory 51 4 along with the other color 
information. 

There are various ways to handle transparent spans within the rasterization method presented in this document. As an 
aid in the following explanations. Figure 46 (a modified version of Figure 11) shows a set of segment spans 4600 to 4613 in a 
raster line where the visible opaque surfaces are shown as thick black lines and the visible portions of the transparent 
spans 4602, 4605, and 4607 are shown as thick shaded lines. This section of the document uses an example with segment 
spans, but the transparency methods can be applied to trapezoidal spans and quadrilateral spans. 
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Version 1: Keeping visibUay ckarncteristie consistent aver the Current Span 

This version of the method keeps the visibility characteristic of the Current Span. % mmlttot hy miHn £ * c m ^ 
tf necessary, when stransp 
parent spans if they are found to occlude 5c. 

example, m Figure 46, when te^ 4601 finds the transparent span S^WZSc is changed to the 

part of S x 4601 between X]L 4624 and ^4626, andS, 4601 is also kept as the Saved Span, 5 S , so that its part to the right of 
xjl 4624 will be the next S 0 When this part becomes Sq Oe, the part of 5 t 4601 between xg. 4626 and ^4628), its SOT 
C^ery also filial Sj 4602, and the »mb^ 
is processed in a similar way. 

When S 4 4604 is reached, it is first processed as its part located between x^ 4630 and 4632 and includes the 
effect of S 2 4602. Then, when S c is the portion of S 4 4604 to the right of x^ 4632. the SOT Query finds both S 5 4605 and 
S 6 4606. At this point, the method and apparatus can be designed to either 1) read the leftmost opaque occluding span; 2) read 
the leftmost transparent occluding span; or 3) read the leftmost span or either type. The first of these choices is assumed here. 
Hence, by a rendering rule similar to Rule 3 2400, S c is reduced to the portion of S 4 4604 between x^ 4632 and x^ 4634. 
But, before 5 C is rendered transparent spans in the SOT Region are read, thus obtainingS 3 4605. Because S 5 4605 covers all of 
S c S 4 4604 between x^ 4632 and x^ 4634), S c is not further divided, and is rendered as the combination ofS 4 4604 and 
S 5 4605 over the interval from x^ 4632 to X€L 4634. Within the same rendering rule, S 6 4606 is made Sp and all of it 4606 is 
designated as Sq. 

The span J 6 4606 is processed similarly to 5 4 4604 m that its first portion, from ^ 4634 to 4636, is combined 
with the transparent span 5 5 4605. Its second portion, from x^ 4635 to x^ 4636, is combined with the transparent span 
5 7 4607. And. its third portion, to the right otx^ 4636. is hidden, ^ ^S 7 4607 btcomcsSj. From x^ABSS to the right, 
the spans are processed be described in previous section because there are no more transparent spans. 
Version 2: Dividing the taster line into pieces where depth risibility changes 

This version of the method follows, in left-to-right order, the frontmost spans whether they are opaque or transparent 
When opaque spans are rendered from left to right up to the«oordinate where a visible transparent span starts, rendering of the 
opaque spans is temporarily suspended (in essence, that tendering process is pushed onto a stack), and rendering shifts to the 
transparent span. Then frontmost transparent spans are rendered from left to right until either 1) the transparent spans end at an 
or<oordinate where either only opaque spans or no spans exist; or 2) the frontmost transparent span is occluded by an opaque 
span. At that point, rendering returns to the rendering of opaque spans that were temporarily suspended (the rendering process 
stack is popped). 

As transparent spans are tendered, they are deleted from the Span Memory 408 in order to keep them from being 
re-rendered later in the method. Because a transparent span can transition from visible to bidden and then become visible again 
as the method renders farther to the right, the visible part that is already rendered needs to be deleted to keep it from being 
re-rendered. This can be done by overwriting the transparent span in the Span Memory 408 and changing its left endpoint Thus, 
when a transparent span is rendered, if it is rendered to its right eridrxrint, it is deleted completely. When a transparent span is 
partially rendered, only the rendered part is deleted. 

In portions of the raster line that have one visible transparent span, the stack-oriented approach renders the transparent 
spans first, then the opaque spans. In portions of the taster line that nave two visible transparent spans (one in front of the other), 
the stack-oriented approach renders the frontmost transparent spans first, then the second from the front transparent spans, and 
finally the opaque spans. As tang as the rendering process stack does not overflow, this method can render any depth of visible 
transparent spans. 

Toe raster line can be thought of as being divided into pieces alx<ooxdinate locations where the visibility depth 
changes (e.g., from one to two, from two to three, from two to one, etc.). Within these pieces, visible spans are rendered in a 
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front-to-badc order. Having the rendering done in front-to-back order lUows pixel color values to be correctly blended. This ii in 
contrast to prior art methods (such as the Z-buffer technique) that renders geometry in random order. 

Uring the sjians shown in Figm o£S 0 4600 
andSj 4601 1© to ^4626. At that poim in the method 

pushed onto the rendering process stack. Next, the transparent spans £ 2 4602, £ 5 4605, and ^4607 are rendered from 
*2L 4626 to *gL 4636. As these spans are rendered, 4602 is deleted, S 3 4605 is deleted, and part ofSy 4607 is deleted by 
changing its left endpoint to (r^ z^) 4640. Next, the rcr^dering process stack is popped, andJ c is restored to the portion of 
S x 4601 between xjl 4626 and 4628. There, rendering of opaque spans resumes, and the visible portions of spans 5, 4601, 
5 3 4603,^ 4 4604, aal5 6 4606 are rerideredfro^ 

the opaque spans are rendered The remaining piece of S 6 4606 is hidden, so the method avoids reading it 4606 from the Span 
Memory 408. 

Version 3: Perform multiple passes 

In this version of the method, a multiple pass strategy is used. In the first pass, all the opaque geometry is rendered 
with the previously described method of this document At the end of rendering the opaque spans, all the Valid Flags 81 6 for the 
opaque spans have been turned off. Then, in the second pass that renders the transparent spans, the Valid Flags 81 6 for all the 
opaque spans are turned on, and each transparent span is then sequentially tested to determine if it is occluded by an opaque 
span, and then its visible portions are rendered. 

As a possible option, as an opaque span ii rendered, a query » done to find all transparent spans that are completely 
behind the opaque span and de-assert the Valid Flags 816 of such transparent spans. This reduces the number of transparent 
spajutr^ are processed and are h^ another query. To 

reduce this overhead, the query that invalidates transparent spans can be done once after every set of abutting opaque spans. 
Hence, when the rendering of a set of abutting spans ends, the maximum r-value of any of the visible portions of spans in the set 
is used as the irunimum i-value in the query to find hidden transparent s 

the next paragraph. This option may consider a single span as a one-span set for use as occluding transparent spans. 

Using the spans shown in Figure 46 as an example, in the first pass of this version of the method renders the visible 
portions of S 0 4600, 5, 4601 , 5 3 4603, and 5 4 4604. At this point in the method, tendering of a set of abutting spans has ended, 
and transparent spans hidden by the set are invalidated by a query that fi^ tzsnsparem spans completely within thex^rdinate 
range of x 1L 4624 to ^ 4634 and having the r-value of both its endpointa greater than 4642. Next the visible part of 
S<5 4606 is rendered. Then, the abutting span set of S 8 4608 and S l0 461 0 is rerjdered, and a query is done to invalidate the trans- 
parent spans behind the set Likewise, when S u 4611 and S l2 4612 are rendered, the same sort of query is done. The other 
opaque spans in the raster line are processed normally. At the beginning of the second pass, all the Valid Rags 81 6 of the opaque 
spans are asserted, and then the transparent spans are sequentially processed in a left-to-right order. In the example,5 2 4602 is 
read from the Span Memory 408, an SOT Query is done for it 4602 which finds no occluding spans, and it is therefore rendered. 
The span S 6 4606 is processed similarly. For ^4607, its SOT Query finds S g 4608, so £7 4607 is only rendered up to 
xgL 4636. Since no other transparent spans are left, this raster line has been completed. 

An optional change to this version of the method is to store the transparent spans in a memory separate from the Span 
Memory 408. Then, in the second pass, each transparent span is read from this separate memory, has an SOT Query done for it 
and has its visible parts rendered. 
Additional considerations for transparencies 

Polygon coloration is frequently described by texture maps. Some texture maps are defined to have some pixels be 
1 00% transparent (perfectly clear). A typical example use of such a texture map is an image of a tree mapped onto a rectangular 
M biUboard-type w polygon (billboard polygons automatically rotate to face the viewing point), where the corners of the rectangle 
are clear, and holes within the tree's image can occur. Polygons with such texture maps need to have their spans processed as 
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trimpffemip« nS .Thijubecii«theyc^ 

texture map with transparent pixel s, s pan s in that pdy«oo are assumed to be transparent, and the totm m. p d frt atrs thr opacity 
coefficient for each of its pixels 

When trapezoidal spans (01 quadrilateral spans) are used, spans thil include come* cod edges of polygons thai have 
either a spaa top or span bottom but not both, can be vme^ulnatpueattpuit.TiueaaU^}KenMtpmofti^type 
do not ooinpletdy occliide more diatant »^ 

can be used to process spans thtt only partially cover the vertical height of the raster line. 
Spaas Represented by Quadrilaterals 

lU^resenhng spans with trapezoids has the disadvantage of requiring the location of four points imr-z plane (not pre- 
cisdy aplane. n h« the thickw* of «ie raster li^^ 
i-values are 32-bitt each. 

In order to reduce the memory requirement*, the endpoint location of a span can be approximated by two jr-values and 
one r-value. In essence, the two points that describe the endpoint have the same 2-coo ruinate, but have different ^-coordinates. 
Therefore, the number of fields for storing coordinates is reduced from eight to six. This introduces a small amount of error in 
the antialiasing methods described above, but the error is only significant for polygons that are nearly parallel to thex-z plane. 
For these polygons, the look direction is very close to being a tangent to the plane of the polygon. However, for most applies- 
lions, this errors is acceptable because the projection of these polygons onto the viewing plane102 has not changed 

Figure 47 shows the trapezoidal spans 5, 4701. S 3 4703. and S t 4704 as dashed lines, and shows the quadrilateral 
approximations of these spans, 5 , 471 1, r 3 4713. and 5\ 4714 a, solid line*. In this figure, endpoint. for the quadrilatoal 
spans are always a horizontal line segment. Figure 48 is similar to Figure 4a except that all the trapezoidal spans have been 
replaced by their trapezoidal approximation. Note that some of the trapezoidal spans appear to fold over themselves. Trapezoidal 
spans can be processed by similar methods to those described in this document for trspezoidal spans. 
Eliminate Current Polygon Memory 406 and read from Sort Memory 404 

By adding more "smarts- to the Bucket Sort Processor 504. the Current Polygon Memory 406 and the Current Poly- 
gon Processor 506 can be eliminated. Figure 49 show, the Span Sorting Rendering Pipeline with Direct Span Generation 4900. 
where the process 1600 data from Bucket Sort Memory and Current Polygon Memory 406 have been eliminated (when com- 
pared to the Span Sorting Rendering Pipeline 400) and the Bucket Sort Memory 404 has been changed to the Sort 
Memory 4804. As polygons are generated by the process polygon 1400 potion of the pipeline 4800. their parameters are writ- 
ten imo the Sort Memory 4904. Keejnng track of the polygons which affect the current raster line is done by maintaining a list of 
pointers into the Sort Memory 4904. rather than copying the polygon parameters to a separate memory (the Current Polygon 
Memory 406). This is accomplished by feeding polygons, at high spaed, directly from the Bucket Sort Processor 504 to the 
Span Generation Processor 508, as shown in the Span Sorting Renders Architecture with Direct Span Generation 5000. This 
has the disadvantage of accessing the Sort Memory 4804 at a much higher late, thus probably requiring the Sort Memory 4804 
to be fast memory, rather than alow memory. 

A decision to use this alternative must be based on an engineering decision between a large last memory (the Sort 
Memory 4804) versus hiving both a large slow memory (the Bucket Sort Memory 404) coupled with a small fast memory (the 
Current Polygon Memory 406). However, in the extreme case where every polygon can affect on particular rasterline, the Cur- 
rent Polygon Memory 406 would need to be as Urge as tte 
a large fart memory even when a separate Current Polygon Memory 406 is used. 
Alternate Representation of Polygons using Derivatives 

As ai»ssftk mn*o*emenu an alternate « 
of derivatives. For example, as shown in Figure 51. a triangle can be represented by the parameters: l)fcy.i) at one 
venex5102: 2)(x.y) at a second vertex 5104; 3)yat the third vertex 5106; 4)0*% for each of the three 
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edges 5108, 5110, 5112 of the triangle, rather than the more usual repnaeaJO^of(^y,j)ueu^ot^^aeeyer^S^2, 
5204, 5206, as shown in Figure 52. In both cases, the number of parameters of the triangle is nine. The improvement is signifi- 
cant because the edge derives 51 08, 511a 5112 are needed for edge walking in both representations (ix^ in Figure 51 and 
Figure 52), and must be computed and stored. Hence, utilizing fewer vertex coordinates (as in Figure 51) saves memory. 
On-the-fly Generation of Subspans 

As shown in Figure 3fi, multiple segment spans can used within a raster lii« to enhance antialiasing. 
tage with having multiple multiple segment spans per raster line is requiring either 1) a corresponding multiplication of the pro- 
cessing perfumed for each raster line; 2) a corresponding multiplication of the hardware, including the Span Memory 408; or 
3) some combination of multiplication of the processing and multiplication of the hardware. 

As a possible improvement for trapezoidal spans and qiiadiilateral spans, the spatial data structure can store the param- 
eiers of the entire span, and when the span is read form the data structure, a set of subspans is generated on the fly, where these 
subspans are vertically distributed over the height of the full span, and each subspan is a segment span. An example of this is 
shown in Figure 53. where eight subspans are shown for the span 5300. The left endpoims, xJ0]530Z xjl]5304, 
xJ2] 5306. *iJ3] 5308, xJ4] 5310. xJ5] 5312. xJS] 5314, and xJ7] 5316, of each subspan are generated utilizing a ver- 
tex's coordinates, edge derivatives, and the y offset from the vertex. The right endpoints, x R [0] 5322, x R [l] 5324, x R [2] 5326. 
x R [3] 5328, x R [4] 5330, x R [5] 5332, x R [6] 5334, and x R [7] 5336, are generated in a similar manner. When subspans are used, 
the locations of the endpoints are stored in the Span Parameters Registers 31 04. which need to be expanded to store the addi- 
tional information. 

When subspans are used, the rule for comparing the Current Span Portion to the New Span are applied on a subspan- 
by-subspan basis, thereby providing additional polygon edge information within a raster line, which, in turn, provides antialias- 
ing. Once again, for real-time performance, the spatial data structure can be stored in a SMCCAM. When a portion of a span is 
determined to be visible due to a portion of the span's subspans being visible, those subspan portions must be sent to the Raster- 
ize Processor 512. However, only the right endpoints of the visible subspan portions need to be sent An example of a visible 
span portion 5400 is shown in Figure 54, and its right endpoints are shown as: x R [0]5402. x R [l]5404, x R [2J5406. 
x R [3) 5408, * R [4] 5410, x R [5] 5412. x R [6] 5414. and x R [7] 5416. The left endpoints do not need to be sent to the Rasterize 
Processor 512 because the left endpoints are equal to the right endpoints of the previously sent visible span portion. Hence, the 
sequence of sets of right endpoints can be thought of as a "wive" traveling along the length of the raster line, where the "wave- 
front" can be an arbitrary shape. Special care must be taken to prevent ••holes" from developing, and therefore disturb the •wave- 
like flow". This is done by finding the visible subspan at the leftmost point among the most recently sent set of right endpoints. 
In the example of Figure 54, the next visible span portion must be located at the pointx R [3] 5408. 
Alternate Representation of Trapezoidal Spans 

The minimum number of queryable parameters for a span stored in the Span Memory 403 are: 1) the leftmost x-value 
of the span, xjr^] 5502; 2) the rightmost x-value of the span, x K [r 5504; and 3) the frontmost x-value of the span, 
2 Mia 5506, which could be located at any corner of the span. These three parameters should be stored in fields within the SMC- 
CAM that can perform arithmetic comparisons. However, it is also important for it to be easy to generate, form the span parame- 
ters, the subspan endpoints for the span, as well as z-values along any point along any subspan within the span. The calculations 
need to generate two types of results: 1) rvalues at any points within the span or along its edges; and 2) tbex-values that define 
the projected edges of the span. A reference point, <x M , y 5508, as shown in Figure 55, can be located at the uppermost sub- 
span y-value within the raster line (even if the span does not touch that part of the raster line). Once this reference point5508 is 
know, the r-value of the span at any location can be computed from thex and y offsets from this reference point 5508 and the 
derivatives, &/6y 5510 and &/&x 5512, of the original polygon. The projected edges of the span must be able to be computed in 
a similar manner, and many choices for parameters are possible, and one possible choice includes: l)the edge derivatives 
6x R /6y 5514 and Bx^y 5516; 2) the uppermost subspan location, r Top 5518; 3) the lowermost subspan location, 5520; 
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4) 'MiaX 5522, the subspan location that includes the rightmost x-value of the span, xjr^j^] 5502; and 5) 5524, the 
subspan location that includes the rightmost x-value of the span, xb[/ - Mm y 1 5504. 

If a raster line includes the comer of a porys^ then the span wiU not hra 
is shown in Figure 56, where the middle (in an up-down sort) comer is included. Since the resulting span in this example would 
have five sides, and therefore can not be modeled ai a trapezoid, the span is split into two spans: 1) the upper trapezoid5602; 
and 2) the lower trapezoid 5604. When an uppermost corner or a lowermost corner of a polygon is included, then the span is 
modeled as a degenerate trapezoid, where two of the four corners are identical. 

Similar alternate representations can be used for quadrilateral spans. 
Preservation of Rendering Order 

For some applications, the order of rendering must be preserved. A typical example is the "painter's algorithm" (see 
Foley Reference, page 674) as used in computer windowing systems. To render an inner rectangle with a boarder, first the 
boarder is rendered as a filled rectangle, then the inner rectangle is tendered, over-writing most of the pixels in the boarder rect- 
angle. If the rendering order of these two rectangles is reversed, then the entire area will have the color of the boarder rectangle 
because the inner rectangle will be completely over-written. If these two rectangles have a distinct placement due to different 
z^coordinates. then they will be rendered correctly. However, if noz-coordinate is specified (the default would be the depth of the 
viewing plane 102). then the order must be preserved. This can be done by having the Bucket Sort Processor 504 and the Cur- 
rent Polygon Processor 506 maintain the order in which they are received from the Polygon Processor502. The Query Proces- 
sor would maintain the rendering order by placing spans for later input polygons into later positions in the span list Then, as 
rendering proceeds, rendering order is preserved because, in the case of ties mz<oordinate, spans earlier in the list will be ren- 
dered first and later geometry with the same 2-coordinate will be assumed to be hidden. 
Method and Apparatus Options and Possible Enhancements 
Add to single buffered VGA graphics card 

The video output for computers (for example, VGA and SVGA interfaces on IBM compatibles) generally includes a 
frame buffer memory that stores the pixel information sent to the display device (Le., the CRT). The 3D graphics rendering meth- 
ods and/or apparatus described here can be added to such a display system. The CPU (or DMA controller) writes geometry into 
the renderer. and il gets processed and stored into the Bucket Sort Memory (which may need to be double buffered). When the 
geometry is done being written, the rest of the pipeline syiichronizes to the computer display, and generates spans before they are 
needed, overwriting the previous frames's data in the computer's frame buffer. Hence, a low cost, but high performance, 3D 
graphics accelerator can be added to a computer without adding more memory to the frame buffer. 
Turn off antialiasing on specific polygon adges 

The antialiasing method described above assumes that every polygon has independent color values; and when abutting 
spans are found, the pixels that include both of the spans need to have their colors be a blend from the two polygons. However, 
polygons that share an edge often have exactly the same color information along the edge. For example, this occurs for Gouraud 
shaded polygons that have the same color and surface normal information at both ends of the same polygon edge. For these types 
of edges, the pixel blending can be ignored because two identical colon will be blended together. Such polygon edges can be 
tagged as "skip antialiasing" when they are supplied to the Tenderer. Then, if such edges are found to be part of an abutting span 
pair, the pixel color value for one of them (say, the one on the right) is skipped, thereby saving computation. Edges that are 
tagged but are not part of an abuttmg span pair are 

not take advantage of this saving because they do not search for abutting spans or polygons. That is, prior art renderers generally 
assume every polygon is independent from all other polygons. If tagging is not done (due possibly to constraints imposed by the 
interfacing software), the Span Sorting Rendering Pipeline 400 can automatically generate such tags for edges within polygon 
meshes and strips where an edge shared between two polygons has the same color information for both polygons. 
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Store edge pairs rather thorn polygon* in B ucktt Sort Memory 404 

Rafter than stare polygons in the Bucket Sort Memory 404, polygon edge pairs can be stored. This means polygons 
are horizomally sliced so that e^ 

izontally sliced at the jjMsxmiinate (or nearby raster line boundary) of comers thai are at neither ysiAKr or This polygon 

sHcing makes dwiislream processing easier by elimi^^ 

polygon. 

Front and rear clipping planes 

By adding clipping planes, the view volume (shaped as an infinite pyramid) is changed into a frustum. Right before 
spans are written into the Span Memory 408, the i-value of their endpoints are ccopared to the i-locarion of the front and rear 
clipping planes. If both endpoints are nearer then the front clipping plane or farther than the rear clipping plane, then the span is 
discarded. If one endpoint is farther than the rear clipping plane, then that end of the span is shortened so that its endpoint is on 
the rear clipping plane. If one endpoint is nearer than the front clipping plane, men that end of the span is shortened so that its 
endpoint is on the front clipping plane. This requires a set of comparators to be added to the either the Span Generation 
Processor 508 or the Query Processor 51 0. 
Multiple arbitrary clipping planes 

An arbitrary clipping plane could be done the same way as simple front and rear clipping planes, except, right before a 
span in written into Span Memory 408, Span Interaction Parameters between the span and the span of clipping plane are gener- 
ated, and these are used, as described above, to detennine the Span Interaction Type (SIT). The span is then kept, clipped, or dis- 
carded depending on the SIT. 

This could also be done by adding dutiunyspaiumto the Span Meinory 408 
cupping plane. Then the rasterization methods described above could be altered to make sure all rendered spans are behind these 
dummy spans. 
Geometry Cache 

A memory at the input to the pipeline could be added to store geometry as it is input for rendering. Then, when subse- 
quent scenes are rendered, this stored (or "cached") geometry can be re-rendered (with possibly changed translation matrices), 
thereby saving cycles on the system bus. This could solve a bottleneck caused by having a Tenderer that can process more geom- 
etry per second than the host computer bus can support It can only shape since its 

previous rendering. "Squish/* objects would generally need to be supplied to the renderer for every scene. 
Use only one page of Span Memory 408 

It is possible to use only one page of Span Memory 408. This is done by shifting valid spans toward upper words, 
leaving lower words invalid. Then, as new spans are generated, store them into the lower words. This strategy can be thought of 
as a single bank of memory that is separated into two pages by a moving bouiidary. This can be done because, as a raster line is 
processed, spans are deleted, while the simultaneous process of preparing for the next raster line generates spans. 

As an alternate approach, the fixed Word Number Held 802 can be changed to a variable Tag Field. Unique (and ran- 
dom will do) tags for each span are written into the Tag Field, and designate if : 1) a span is m the currem raster line or the next 
raster line; and 2) be a unique identifier for the span. FurtheraKm^theTagscmte 

from the current raster line can be intermixed with those in the next raster line. As long as spans in the same raster line are kept 
in order with respect to each other, then spans from an unrelated raster line can be mtermixed as long as they are ignored This 
could be done by maintaining two sets of Valid Flags 81 6, one for each raster line. Spans from more raster lines could be simul- 
taneously maintained by adding more sets of Valid Flags 81 6. 
Separate Read and Write Busses in the Span Memory Page 

The circuit for the SMCCAM Cell 3400 or 3500 can be modified to have both an input bus and an output bus. This 
allows simultaneous read and write operations. The is specially useful if there is only one page of Span Memory 408 as 
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described in the previous section. 

Computing SIP and SIT only when bounding boxes overlap 

Rather than computing the SIT for every New Span, S N , compute it sequentially with less hardware only when bound, 
ing boxes overlap. This sacrifices time in order to save circuitry. 
Sp lit raster line into smaller pieces to save on SMCCAM memory 

Hie total number of words in the Span Memory Page 800 imposes a limit cm the number of spans that can be pro- 
cessed for a given raster line. This limitation can be overcome by conditionally splitting the raster line in half (or more pieces if 
necessaryX and passing through the span data twice. This dec^ 
decision before rendering starts. 

Havt an overflow RAM to save spans that are skated out during sort operations 

Rather than splitting the raster line in to pieces, the Span Memory Page 800 can be augmented with an "overflow 
RAM" that stores spans as they are shifted out of the last SMCCAM Word 800. Shifted out spans would start at far right of ras- 
ter line, so the left side of the raster line could be processed normally until gets to left of leftmost shifted out span. Then, 
shifted out spans could be re-written into the Span Memory Page 800 because may spans have been deleted (Le„ invalidated) by 
the rasterizing process. 

Inclusion rendering primitives other than polygons 

Geometry primitives other than polygons (such as CSG primitives) can be processed by the Span Sorting Rendering 
Pipeliiie 400. This can be dow as tong as they^^ 

the Bucket Sort Memory) and spans with bounding boxes can be generated. The comers of the bounding box are used as the 
Span Parameters, and SOT Queries can be used to find the visible portions of the bounding boxes. Another set of Span Interac- 
tion Types would be needed for the specific set of geometry primitives. 
Low cost version can use CPU for front end 

The host CPU. or a dedicated general-purpose processor, could perform the tasks of the Polygon Proccssor502, thus 
feeding geometry in screen coordinates (in object-precision) to the rest of the pipeline. Similarly, such a CPU could perform 
more of the front end of the pipeline 400. For example, a CPU and its general purpose memory could perform the tasks of the 
Polygon Processor 502, the Bucket Sort Processor 504, and the Bucket Sort Memory 404, and feeding polygons that start on 
the present raster line to the rest of the pipeline. 
Alternate sorting mechanism could use up-counting tag 

The Word Number Field 802 could be replaced with a conditional up-counter, in order for shifting to be elirninated 
from the SMCCAM. When a new span is being written to the SMCCAM, a query determines which spans should be later in the 
sorted list than the new span. Such "later" spans have their up-counter incremented, and no shifting is performed. The up-counter 
for the new span would be assigned the lowest counter number in the list of "later" spans before the up-count takes place. 

This approach means the "get the first span in the sorted list" becomes "find the smallest counter value" in the Span 
Memory 408. Hence, the sorting (Le., shifting) is replaced with a new search type. Far this to be fast, the hardware would need 
to have a "find the smallest" function associated with the set of up-counters. Also, this "find the smallest" could be performed in 
bit-serial method 
Using a generic CAM 

Generic, prior art CAMs could be used, but m ng n inidr comparisons would be bit sequential. This would greatly slow 
the processing, but may afford some cost savings in the hardware. This alternative would probably use the up-counting tag, as 
described in the previous section. 
Using multiple registers per arithmetic comparator 

The above description of the SMCCAM assumes a one-to-one match between memory register and arithmetic compar- 
ators. An alternate approach is to have all the memory registers in the same word share a single arithmetic comparator. This saves 



WO 97/05576 PCT/US96/12390 

-61- 

on circuitry, but slows the processing. However, since not all fields participate in every query operation, the performance loss is 
not proportional to the total number of fields. 

Other alternate approaches could share comparators between words, or between words and fields. These approaches 
further reduce the amount of hardware, but further reduce the performance. If any of these snared canparator approaches are 
used, then a standard six-transistor RAM cell should be used because it provides the greatest density. Hence, the searching and 
sorting hardware could be made from a set of multiple-word memories, where eacb such rnemory has one or more comparators 
associated with it 

Using a RAM-bated sorting processor 

An alternative to using a CAM of any type can be done by having a Cast linked list sorting processor. By utilizing fast 
mernory, spans cx>uU be sorted into since spans are 

added and deleted frequently, this approach might be very slow. The advantage is the ability to use fast off-the-shelf RAMs that 
are readily available. 

To aid in SOT Query operations, a two^imensional data structure could be used that sorts the spans in both the* and 2 
dimensions at the same time. Such a searching and sorting structure is described on pages 24 to 55 of "Data Structures and Algo- 
rithms 3: Multidimensional Searching and Computational Geometry", by Kurt Mehlhom, a volume in the EATCS series on 
Monographs on Theoretical Computer Science, edited by Brauer. W„ et aLJSBN 0-387-13642-8, published by Springer-Verlag. 
New York, 1985. 
Shadow processing 

Because shadow computations are essentially the same as hidden surface removal, the Span Sorting RendererSOO can 
be used for shadow computation. This can be done by utilizing multiple Span Sorting RenderersSOO in parallel, or it can be 
done by rime-sharing one Span Sorting RendererSOO. 
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What is Claimed is- 

1. A sorting magnitude comparison content addressable memory (SMCCAM) comprising: 

a plurality of registers in a single sort memory storage, said registers including a plurality of registers for storing a 
polygon's span parameters, and memory location pointers pointing into said single memory identifying the locations of a 
current polygon; 

means for performing a bucket sort within said memory; 

means for storing current polygon data in said memory; 

said appararatus operable with a single Sort Memory in place of separate and distinct Bucket Sort Memory and 
Current Polygon Memory, to store polygon geometry information once that geometry information has been translated to screen 
coordinates, and 

a function provided by a Current Polygon Memory being provided by a set of pointers into said Sort Memory, 
thereby eliminating copying Polygon Parameters from said Bucket Sort Memory into said Current Polygon Memory; and 

query means for performing a query operation between at least two different polygon spans based on comparisons of 
said stored span parameters between said at least two different polygon spans to determine which of said spans is visible and 
which of said spans is occluded. 

2. An anti-aliasing processor apparatus for graphical data, said apparatus comprising: 
memory storage means defining a data structure and storing each entire polygon span; 

means for generating a set of subspans on the fly as each said span is read from said data structure defined in said 
memory storage means, each said subspan being a segment span, and said subspans being vertically distributed over the height 
of the full span; and 

means for applying a rule for comparing the Current Span Portion too a New Span portion on a subsnan-by-subspan 
basis thereby providing additional polygon edge information within a raster line to provide anti-aliasing. 

3. The apparatus in Claim 2, wherein said spatial database is defined within a sorting magnitude comparison 
content addressable memory (SMCCAM). 

4. The SMCCAM in Claim 1, wherein said query means further comprises Span Occluding Test (SOT) means 
for performing a Span Occluding Test to determine which of said spans is visible and which of said spans is occluded. 

5. A span sorting rendering apparatus comprising: 
a polygon processor; 

a bucket sort processor; 
a current polygon processor; 
a sort memory; 
a span generation processor, 
a query processor, 

a span memory coupled to said processor; 

a rasterize processor; and 

a raster line memory coupled to said rasterizer. 
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6. In a memory apparatus having a plurality of storage registers for storing data, and a data structure defined 
within said memory apparatus, a method for testing for span occultation of a current span by a selected different span, said 
method comprising the steps of: 

receiving a polygons* span parameters and storing said parameters in predetermined storage locations within said data 

structure; 

performing a span occluding test query operation between at least two different polygon spans based on comparisons 
of said stored span parameters between said at least two different polygon spans to determine which of said spans is visible and 
which of said spans is occluded; and 

storing said span occluding test query results in said data structure. 

7. The method in Claim 6, wherein: 

said step of receiving a polygon's span parameters and storing said parameters comprises storing parameters for an 
entire polygon span; and further comprising the steps of: 

generating a set of subspans on the fly as each said span is read from said data structure defined in said memory 
storage means, each said subspan being a segment span, and said subspans being vertically distributed over the height of the 
full span; and 

applying a rule for comparing the Current Span Portion to a New Span portion on a subspan-by-subspan basis 
thereby providing additional polygon edge information within a raster line to provide anti-aliasing. 
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. AMENDED CLAIMS 

[received by the International Bureau on 03 January 1996 (03 01 97) - 
orignal claims 1-7 replaced by amended claims 1-28 (7 pages)] 



1 . In a graphical processing system for processing 3-dimensional object geometry 
data and rendering at least some of said object geometry data on a 2-dimensional 
display screen, a method for rendering a scan line comprising the steps of: 

(a) Transforming an object geometry data into a polygonal 
representation, said polygonal representation comprising at least one 
polygon, each or said polygon defined by a set of polygon parameters 
including polygon vertices having display screen relative coordinates; 

(b) Sorting said polygons using a bucket sorting routine wherein a 
separate memory bucket is allocated for each display raster line and a 
polygon is placed into the one particular bucket that corresponds to its 
starting raster line; and 

(c) For each display raster scan line: 

(i) Maintaining a list of all current polygons that intersect the 
raster scan line currently being rendered; 

(ii) Generating a span for each polygon that intersects the 
current said display raster scan line based on geometric 
properties of said polygon including said polygon parameters, 
having each said span include subraster information describing 
the geometric shape of the span within the vertical extent of the 
raster scan line; 

(iii) Storing geometric properties of each said generated span 
into a span memory; 

(iv) Maintaining a current span portion that is part of a span that 
is potentially visible, said current span portion comprised of a set 
of current subspans, each said current subspan representing a 
rectangular area within the said current span portion, and said 
set of current subspans approximating the area of said current 
span portion. 
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(v) Performing one or more span occluding tests to find any 
new span that potentially occludes said current span portion; 
where said span occluding test comprises the steps: 

(1) determining the leftmost, rightmost, and farthest 
spatial coordinates in the said set of current subspans; 

(2) performing a query operation on the said stored 
geometric properties in said span memory to find all said 
spans whose stored geometric properties include: a 
spatial coordinate located between said leftmost and said 
rightmost spatial coordinates of the said set of current 
subspans; and a spatial coordinate closer than the said 
farthest spatial coordinate of the said set of current 
subspans. 

(vi) Generating set of new subspans, each said new subspan 
representing a rectangular area within the said new span, and 
said set of new subspans approximating the area of the said new 
span, 

(vii) For each said subspan in said set of current subspans, 
performing a subspan comparison comprising the steps: 

(1) a spatial comparison between said subspan in the 
said set of current subspans and a corresponding subspan 
in the said set of new subspans, and 

(2) determining the visibility, partial visibility, or non- 
visibility of each subspan in the said set of current 
subspans. 

(vi) Updating said current span portion based on results of said 
subspan comparisons. 

2. The method in Claim 1, wherein said span memory comprises a data array in a 
random access memory (RAM). 
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3. The method of Claim 1, further comprising the steps of: rasterizing said spans 
or said portions of spans that are visible by rasterizing visible said current supspans. 

4. The method in Claim 1, wherein said step of storing geometric properties of 
each said generated span into a span memory further comprises the steps of: 

(a) comparing said span data being stored into said span memory to 
span data previously stored into said span memory to thereby compare 
first stored data directly with second stored data; and 

(b) inserting said span data being stored into said span memory so as to 
maintain a sorted list of said span data within said span memory. 

5. The method in Claim 4, wherein said step of storing geometric properties of 
each said generated span is in order of precedence by left x-coordinate. 

6. The method in Claim 1 , wherein said rendering is performed by identifying 
visible polygon spans than can be rendered without performing pixel-by-pixel z-buffer 
comparisons. 

7. The method in Claim l % wherein said step of maintaining a list of all current 
polygons includes the steps of: discarding the sorted list of polygon spans from 
processing a previous raster line; and building a new sorted list for each raster line as it 
is processed. 

8. The method in Claim 1, wherein said display screen relative coordinates include 
the location in object - precision screen coordinates of polygon vertices for said object 
geometry. 

9. The method in Claim 1, wherein said coordinates are not limited to coordinates 
within the bounding area of said display screen. 
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10. The method in Claim 1, wherein said step of sorting said polygons using a 
bucket sorting routine includes the steps of generating one linked list per bucket, and 
using said linked list to perform said sorting. 

11. The method in Claim 1, wherein said polygon parameters include: the location 
of said polygon vertices in object-precision screen coordinates, color information, edge 
derivatives for each polygon edge, starting raster line, ending raster line, and span 
derivative. 

12. The method in Claim 1, wherein said span memory comprises a double buffered 
span memory having first and second banks, wherein said span geometric properties are 
written to said first bank; and wherein simultaneous to writing span geometric 
properties into said first bank, span geometric properties in said second bank are 
processed to identify visible span portions. 

13. The method in Claim 1, wherein said rendering is performed with sufficient 
speed to provide real time image generation. 

14. The method in Claim 1, wherein said span memory comprises a said sorting 
magnitude comparison content addressable memory (SMCCAM), said sorting 
magnitude comparison content addressable memory (SMCCAM) performs said query 
operations, and said sorting magnitude comparison content addressable memory 
(SMCCAM) apparatus comprises: 

Means for storing a plurality of words, each of said words comprising a 
plurality of data fields, each of said data fields being divided into a plurality of data bits; 

Means for providing an input comprising a plurality of input fields 
matching some of said data fields, each of said input fields divided into input bits so as 
to have a one-to-one bit correspondence to said data bits in said data fields in said 
words; 

Query means for simultaneously comparing said plurality of input fields 
to all said words, with simultaneous field comparisons such that each said data field is 
compared to its corresponding input field, and for generating a one-bit query result for 
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each said word which query result is true when all said data fields within said word 
which are compared to one of said input fields compare favorably to each 
corresponding input field; 

Flag memory storage means for storing a flag bit equal to said query 
result for each of said words; and 

Shifting means for conditionally shifting data stored in said data fields of 
each said word to corresponding fields of a different adjacent word said flag bits stored 
in said words. 

1 5. The method of Claim 14, further comprising the steps of: rasterizing said spans 
or said portions of spans that are visible by rasterizing visible said current supspans. 

16. The method in Claim 14, wherein said step of storing geometric properties of 
each said generated span into a span memory further comprises the steps of: 

(a) comparing said span data being stored into said span memory to 
span data previously stored into said span memory to thereby compare 
first stored data directly with second stored data; and 

(b) inserting, said span data being stored into said span memory so as to 
maintain a sorted list of said span data within said span memory. 

17. The method in Claim 16, wherein said step of storing geometric properties of 
each said generated span is in order of precedence by left x-coordinate. 

18. The method in Claim 14, wherein said rendering is performed by identifying 
visible polygon spans than can be rendered without performing pixel-by-pixel z-buffer 
comparisons. 

19. The method in Claim 14, wherein said step of maintaining a list of all current 
polygons includes the steps of: discarding the sorted list of polygon spans from 
processing a previous raster line; and building a new sorted list for each raster line as it 
is processed. 
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20. The method in Claim 14, wherein said display screen relative coordinates 
include the location in object - precision screen coordinates of polygon vertices for said 
object geometry. 

21. The method in Claim 14, wherein said coordinates are not limited to 
coordinates within the bounding area of said display screen. 

22. The method in Claim 14, wherein said step of sorting said polygons using a 
bucket sorting routine includes the steps of generating one linked list per bucket, and 
using said linked list to perform said sorting. 

23. The method in Claim 14, wherein said polygon parameters include: the location 
of said polygon vertices in object-precision screen coordinates, color information, edge 
derivatives for each polygon edge, starting raster line, ending raster line, and span 
derivative. 

24. The method in Claim 14, wherein said span memory comprises a double 
buffered span memory having first and second banks, wherein said span geometric 
properties are written to said first bank; and wherein simultaneous to writing span 
geometric properties into said first bank, span geometric properties in said second bank 
are processed to identify visible span portions. 

25. The method in Claim 14, wherein said rendering is performed with sufficient 
speed to provide real time image generation. 

26. The method in Claim 14, wherein said new sorted list is generated within about 
two clock cycles per stored data value, whereas during first said clock cycle, a query 
operation determines which said words perform said conditional shifting; and during 
second said clock cycle, said geometric properties of said span are written into said 
span memory. 
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27. The method in Claim 14, wherein hidden surface removal is performed by 
processing spans rather than pixels, thereby reducing computation for scenes with any 
significant depth complexity. 

28. The method in Claim 14, wherein said polygon spans are stored in a SMCCAM, 
and wherein said step of performing a query further comprises directly querying the 
entire set of polygon spans stored in said SMCCAM to identify visible spans so that the 
number of comparison operations is proportional to the number of visible polygon 
spans which is a number smaller than the total number of spans. 
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Figure 2 Generic 3D Rendering Pipeline 



2QQ 

Prior Art 



c 



c 



data input 



224^ 



^ frame buffer 



202^ 




transformation 








clip test 




206 v. 


*> face determination 


208^ 




lighting 




210^ 




clip (if needed) 




212- 




perspective divide 




214^ 
216^ 




screen space 
conversion 






set up for 
incremental render 


j 


218^ 










edge walk 




220^ 


span interpolation 


222- 




z-buffered blend 


j 



l floating-point 
' intensive functions 250 



226 



228-. 



y drawing intensive 
functions 260 



double buffered MUX 
output lookup table 



digital to analog 
conversion 



J 



WO 97/05576 



PCT/US96/12390 



3/65 



Figure 3 Generic 3D Rendering Method 
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Figure 4 Span Sorting Rendering Pipeline 
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Figure 13 Span Sorting Rendering Method (SSRM) 
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Figure 14 Process Polygon Method (in SSRM) 
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Figure 15 Process Current Polygon Memory (in SSRM) 
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Figure 16 Process Bucket Sort Memory (in SSRM) 
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Figure 17 Write Span Parameters into SMCCAM 
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Figure 18 Simplified Span Rasterization Method 
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Figure 20 Types of Span Interactions 

Figure 20A: Interaction Type 1 = (Near, Near, Non, Non) => Rule 5 
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Figure 20B: Interaction Type 2 = (Near, Far, Non, Non) => Rule 4 




Figure 20C: Interaction Type 3 = (Near, Equal, Non, Non) => Rule 5 
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Figure 20D: Interaction Type 4 = (Far, Near, Non, Non) => Rule 3 




Figure 20E: Interaction Type 5 = (Far, Far, Non, Non) => Rule 3 
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Figure 20 (continued) Types of Span Interactions 

Figure 20F: Interaction Type 6:(Far, Equal, Non, Non) => Rule 3 
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Figure 20G: Interaction Type 7 = (Equal, Near, Non, Non) &» Rule 5 
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Figure 20H: Interaction Type 8 = (Equal, Far, Non, Non) => Rule 3 




Figure 201: Interaction Type 9 = (Equal, Equal, Non, Non) =» Rule 5 




Figure 20J: Interaction Type 10 = (Near, Non, Non, Near) => Rule 4 
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Figure 20 (continued) Types of Span Interactions 

Figure 20K: Interaction Type 11 = (Near, Non, Non, Far) => Rule 5 




Figure 20L: Interaction "type 12 ■ (Near, Non, Non, Equal) => Rule 5 
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Figure 20M: Interaction "type 13 = (Far, Non, Non, Near) => Rule 3 
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Figure 20N: Interaction Type 14 = (Far, Non, Non, Far) => Rule 3 
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Figure 20 (continued) Types of Span Interactions 

Figure 20P: Interaction Type 16 = (Equal, Non, Non, Near) => Rule 3 




Figure 20Q: Interaction Type 17 = (Equal, Non, Non, Far) => Rule 5 
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Figure 20R: Interaction Type 18 = (Equal, Non. Non, Equal) =* Rule 5 




Figure 20S: Interaction Type 19 = (Non, Near, Near, Non) impossible 
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Figure 20T: Interaction Type 20 = (Non, Near, Far, Non) Rule 5 
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Figure 20 (continued) Types of Span Interactions 

Figure 20U: Interaction Type 21 = (Non, Near, Equal, Non) => Rule 5 




Figure 20W: Interaction Type 23 = (Non, Far, Far, Non) Rule 4 




Figure 20 Y: Interaction Type 25 = (Non, Equal, Near, Non) => impossible 
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Figure 20 (continued) Types of Span Interactions 

Figure 20Z: Interaction Type 26 = (Non, Equal, Far, Non) => Rule 5 
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Figure 20AA: Interaction Type 27 = (Non, Equal, Equal, Non) => Rule 5 
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Figure 20BB: Interaction Type 28 - (Non, Non, Near, Near) impossible 
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Figure 20CC: Interaction Type 29 = (Non, Non, Near, Far) =* impossible 
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Figure 20DD: Interaction Type 30 = (Non, Non, Near, Equal) => impossible 
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Figure 20 (continued) Types of Span Interactions 

Figure 20EE: Interaction Type 31 = (Non, Non, Far, Near) => Rule 4 
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Figure 20FF: Interaction Type 32 = (Non, Non, Far, Far) =» Rule 5 
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Figure 20GG: Interaction Type 33 = (Non, Non, Far, Equal) Rule 5 
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Figure 20HH: Interaction Type 34 = (Non, Non, Equal, Near) => impossible 
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Figure 20 (continued) Types of Span Interactions 

Figure 20JJ : Interaction Type 36 = (Non, Non, Equal, Equal) => Rule 5 




Figure 20KK: Interaction Type 37 = (Equal, Near, Equal, Non) =» Rule 5 




Figure 20MM: Interaction Type 39 « (Equal, Equal, Equal, Non) m Rule 5 
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Figure 20NN: Interaction Type 40 = (Equal, Non, Equal, Near) => impossible 
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Figure 20 (continued) T^pes of Span Interactions 



Figure 20NN: Interaction Type 41 = (Equal, Non, Equal, Far) =» Rule 5 




Figure 20QQ: Interaction Type 43 = (Near, Equal Non, Equal) => Rule 5 
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Figure 20RR: Interaction Type 44 = (Far, Equal, Non, Equal) Rule 3 
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Figure 20SS: Interaction Type 45 = (Equal, Equal, Non, Equal) => Rule 5 




© («") m 



WO 97/05576 



PCT/US96/12390 



29/65 

Figure 20 (continued) Types of Span Interactions 

Figure 20TT: Interaction Type 46 = (Non, Equal, Near, Equal) => impossible 




Figure 20UU: Interaction Type 47 = (Non, Equal, Far, Equal) => Rule 5 




Figure 20V V: Interaction Type 48 = (Non, Equal, Equal, Equal) Rule 5 
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Figure 21 Se gment Spa n Rasterization Method (SSRM) 
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Figure 22 Rule 1 of SSRM 
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Figure 23 Rule 2 of SSRM 
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Figure 24 Rule 3 of SSRM 
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Figure 25 Rule 4 of SSRM 
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Figure 26 Rule 5 of SSRM 
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Figure 32 Comparison and Offset Computation 
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Figure 33 Prior Art MCC AM Cell 
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Figure 34 Generic SMCC AM Cell 
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Figure 35 Static SMCCAM Cell 
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Figure 36 Dynamic SMCCAM Cell 
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Figure 37 Array of SAM Cells 
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Figure 49 Span Sorting Rendering Pipeline with 
Direct Span Generation 
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